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PREFACE 

AUDIENCE 

This P/25 Hardware Engineering Manual is intended for use by 
engineers and technicians who need to understand the P/25 in 
order to modify it, repair it or interface other equipment. It 
describes the P/25 down to the component level. 

This is not a user's guide or a programming manual. While users 
and programmers might find the information useful, for day-to-day 
instructions, they should see the P_lejms £/25 User 's flanual. For 
programming information, they should see the Plexus V7 UNIX 
Programmer's Manual — vol I, 2A aM 2B. 

A working knowledge of digital theory and/or computer 
architecture is necessary to make full use of this manual. 

EQUIPMENT LEVEL 

This manual is current as of July, 1982. It describes systems 
having both 4 and 5 Mhz system clocks and memory boards with 64K 
RAM chips. Earlier systems may have memory boards with 16K RAM 
chips. 

CONTENTS 

Except for the system overview, each section in this manual 
describes a particular P/25 PCB. Each PCB is responsible for a 
distinct set of system functions, so each section describes both 
a PCB and a set of system functions. 

The sections in this manual are as follows: 

System Overview — Describes the entire system at a basic 
level. Read the overview first to obtain a feeling for the 
entire system. This will enhance understanding of any 
sections read later. 

Processor — Describes the Processor board, which contains the 
Central Processing Unit (CPU) and the Memory Management Unit 
(MMU) . This is the controller for the entire system; each 
P/25 contains one and only one processor board. 

Input/Output Controller — The input/output controller is 
really an intelligent communication processor (ICP) that 
controls interaction with up to eight serial I/O ports (RS232C 
standard) and one parallel port (Centronics standard) . Each 
P/25 contains one or two ICPs. 

Memory — While there is memory on every PCB in the P/25, this 
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section describes the system main memory (dynamic RAM) which 
connects to the rest of the P/25 via connector P2 from the 
processor board. Each P/25 contains one or two memory boards. 

Backplane — The backplane connects the components of the P/25 
to each other. It consists of an industry standard Multibus 
(P796 Standard) and connector P2 which connects system memory 
to the processor. An IEEE. Proposed Microcomp uter System Ens. 
Standard ( P7 96 Bus) is included in this section. 

Disk and Tape Controller — This section describes the 
Intelligent Mass Storage Controller (IMSC) which controls 
interaction with 1 to 4 SMD type disk drives and a streaming 
cartridge tape drive. 

The figures and schematics for each section are at the end of the 
section. 
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1 . INTRODUCTION 

The Plexus Computers P/25 is a 16-bit multiprocessing 
minicomputer designed specifically to run the UNIX* operating 
system. It supports 512K to 2M bytes of error-correcting memory, 
16 terminals (serial ports) / two parallel ports (printers) , one 
streaming cartridge tape drive and one to four SMD-interface disk 
drives. The standard configuration includes a 22, 36 or 72M-byte 
(formatted) fixed Winchester disk drive and a 20M-byte four-track 
cartridge tape drive. 

The P/25 uses an industry standard Multibus** backplane (IEEE 
P796 Standard) , and a storage module disk (SMD) interface. This, 
combined with the UNIX operating system, increases the ability of 
designers to rapidly integrate software and hardware to meet 
specific application needs. 

The P/25 has from 3 to 5 asynchronous processors. The central 
processing unit (CPU) , which executes system processes and user 
programs, contains a Zilog Z8001A. It is helped by at least two 
other processors - a disk and tape controller, and an intelligent 
communication processor (ICP) . These peripheral controllers 
handle all interaction with disks, tape drives, terminals and 
printers independently of the CPU, using DMA to access memory. 
This deloads the Z8001A, leaving it free to execute instructions 
without handling many of the routine interrupts. 

The P/25 also supports one or two user-supplied Multibus- 
compatible PC boards which plug into the Multibus backplane. 

The standard P/25 is composed of the following major components: 

Central Processor Unit 

Memory Management Unit 

Memory Array 

Intelligent Communication Processor (ICP) 

Intelligent Mass Storage Controller (IMSC) 

Power Supply 

Multibus Backplane 

Winchester Disk Drive 

Streaming Cartridge Tape Drive 

Enclosure 

Each of the components is described in the following sections. A 



* 



UNIX is a trademark of Bell Laboratories. Plexus Computers 
InC ** S licensed t0 distribute UNIX under authority of AT&T. 
Multibus is a trademark of Intel Corporation. 
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block diagram (Figure 1) shows how they are interconnected. 

2. CENTRAL PROCESSOR UNIT (CPD) 

Each P/25 is equipped with one processor board, which contains 
the central processor unit and the memory management unit mounted 
on a double-height Multibus card. 

2.1. Processor 

The CPU uses a Zilog Z8001A microprocessor which runs at 5-Mhz 
The board includes latches, buffers, control lines, local 
peripherals and local memory to support the Z8001A. It accesses 
all other system boards through the Multibus (connector PI) 
except system memory which it accesses through connector P2. 

2.1.1. Local Peripherals 

The system CPU controls the following local peripheral devices 
located on the processor board: 

Counter/Timer Circuit — The CPU has access to a 4-channei 
Zilog Z80B counter/timer circuit. Channel is connected to 
channel 1 and programmed to divide the system clock down to 50 
hz. The output signal of channel 1 is used to generate 
realtime interrupts to the Z8001A. Channels 2 and 3 are 
uncommitted and available for general software use. 

Programmable Interrupt Controller ~ Interrupts to the Z8001A 
are controlled by a programmable interrupt controller (PIC) , 
which receives interrupt requests from various devices and 
passes interrupts to the Z8001A based on priority. 

Clock/Calender — A clock/calender circuit (realtime clock) 
gives the CPU access to time-of-day in hours, minutes and 
seconds, and days, months and years. A battery powers it for 
up to three months after system power is removed. 



2.2. Software 

The CPU uses four of the Z8001A address spaces. Standard I/O 
space communicates with ports on the Multibus. Special I/O space 
controls peripheral circuitry on the processor board. Memory 
instruction space and data space are used to access memory. 

The CPU uses three of the Z8001A interrupt and trap capabilities. 

2 Overview 
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Nonmaskable interrupts are used for power-fail detection. 
Vectored interrupts inform the Z8001A that a controller on the 
Multibus requires service, and a segment trap informs the Z8001A 
that an MMU error has occurred. 

The Z8001A can be reset by asserting the Multibus INIT/ line, or 
it can reset itself by causing the INIT/ line to be asserted. it 
can also reset all Multibus controllers with the INIT/ line 
without resetting itself. 

2.3. Diagnostic Port 

The CPU has direct control of a diagnostic console port which 
attaches to connector P3. 

3. MEMORY MANAGEMENT UNIT (MMU) 

The memory management unit (MMU) , located on the processor board, 
controls access to system memory. It receives logical memory 
addresses from the CPU or peripheral controllers and converts 
them into physical memory addresses for access to the memory 
array. It also handles memory protection, error detection and 
correction, and refresh. 

3.1. Page Map SAM 

The MMU contains a page map RAM which, under the control of the 
operating system, remembers the differences between physical 
memory addresses and logical' memory addresses. This allows 
different programs and processes to use the same instruction set 
simultaneously. The physical memory consists of 3 2 map sets of 
32 pages, each containing space for 2K bytes. 

3.2. Memory Protection 

Each page can be assigned a read-only and an invalid status. 
These protect critical data from illegal instructions. Memory 
accesses which do not match the page status are not allowed. 

3.3. Error Detection and Correction 

The MMU contains an AMD 2960 error detection and correction 
circuit which generates checkbits based on a modified hamming 
code. When data is stored in memory, a set of checkbits are 
stored with it. When the data is retrieved, a new set of 
checkbits are generated and compared with the old set. it they 
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are not identical, it attempts a correction and sends the proner 
signal to the CPU. * 

3.4. Refresh 

Refresh circuits for system memory are located on the processor 
board. It provides an 8-bit refresh address every 14.4 
microseconds using a cycle-stealing technique. 

4. MEMORY ARRAY 

The P/25 memory array consists of three types of memory: dynamic 
RAM, EPROM, and static RAM. The dynamic RAM is located on 
separate printed circuit boards, while the EPROM and static ROM 
are located on the processor board. 

4.1. Dynamic RAM Array 

Dynamic RAM is the major component of system memory. It occupies 
physical addresses from 100,000 to 300,000H when fully equipped, 
and is the only system memory used during normal operation. 

The dynamic RAM boards each contain 256K, 512K or 1024K bytes of 
memory arranged in 2-byte words. Each word consists of 16 bits 
of data and six error-correction bits. Each board also contains 
basic support functions for the RAM, including address decoders, 
buffers and RAS/CAS multiplexors. All control, address and data 
lines for the RAM array come from the MMU over a dedicated bus on 
connector P2. Although an array board occupies a slot in the 
Multibus backplane, it takes only power and ground from the 
Multibus connector. 



4.2. EPROM 

The EPROM contains the bootstrap instructions used to load the 

operating system. It also contains data used for factory testing 

and diagnostics. It occupies physical memory addresses from to 
3fff. 

Four sockets for EPROM are located on the CPU board. The sockets 
accommodate either 2K x 8 (2716) or 4K x 8 (2732) MOS EPROMS. 
The minimum EPROM configuration is 2K words (two 2716 EPROMs) and 
the maximum is 8K words (four 2732 EPROMs) . A jumper on the 
board is used to select the EPROM size. The access time is 450 
nsec. A single wait-state is added when the CPU accesses the 
EPROM. 
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No error correction or detection is performed on accesses to 
EPROM. 



4.3. Static RAM 

The CPU has IK words of static RAM which occupies addresses from 
8000 to 87FE. It is implemented with four IK x 4 static RAMS 
(2114). The RAM is byte-addressable and is used principally for 
diagnostic and initialization routines. 

The static RAM has a 450-nsec access time, so a single wait-state 
is added when the CPU accesses static RAM. No error correction 
or detection is performed on accesses to static RAM. 

5. INPUT/ODTPDT CONTROLLER 

The input/output controllers are intelligent communication 
processors (ICPs) that handle data movement between terminals and 
printers and system memory. They use direct memory access (DMA) 
to bypass the CPU, freeing it from handling I/O interrupts. Each 
ICP controls eight serial ports (terminals) and one parallel port 
(printer) . Each P/25 is equipped with one or two ICPs. 

The ICP is a double-height Multibus card that features a Zilog 
Z8002 microprocessor. 

5.1. Serial Ports 

The eight RS232C serial ports are implemented with Z80A SIO/2 
USARTS. They support baud rates from 50 to 38. 4K hz by 
programming a Zilog CTC Counter/Timer. Each channel has its own 
DMA channel to move data from local memory to the transmit line. 
A DMA transfer is initiated by the SIO when its transfer buffer 
becomes empty. A rotating priority scheme ensures that the most 
recently serviced SIO has the lowest priority. 

5.2. Parallel Port 

The ICP has a single DMA-supported parallel port used to connect 
an industry-standard (Centronics-type) printer. Control logic 
associated with the port generates all the handshake signals 
necessary for the DMA to transfer data to the printer without 
intervention from the CPU. 
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5.3. Local Memory 

Each ICP is equipped with 3 2K bytes of dynamic RAM, including 
parity bits and refresh. This is used to store operating 
instructions for the ICP and to buffer data between transfers. 

5.4. Pseudo DMA 

The ICP uses pseudo DMA to move data from its local RAM to 
system memory. The Z8002 initiates block moves between the local 
RAM and a 16K section of its memory space that is mapped into 
main memory. This can run in the background, without 
monopolizing either the Multibus or the local bus. 

6. INTELLIGENT MASS STORAGE CONTROLLER (IMSC) 

The IMSC is an intelligent disk and tape controller that contains 
an onboard Z8001 microprocessor. It receives commands from the 
CPU to move blocks of data between system memory (RAM) and the 
disk drives or tape drive. It has 128K bytes of local RAM which 
it uses to buffer entire disk tracks, thus decreasing the number 
of real disk accesses when two different processes require 
constant access to the disk. The buffers store the information 
from the disk and pass it to each process as if it were the only 
process using the disk. 

The disk interface is an industry-standard SMD type. The tape 
drive is intelligent, performing many of the functions normally 
required of the tape controller. It communicates with the IMSC 
over eight data lines and eight control lines. 

The IMSC has three distinct DMA circuits on board. A Z80 DMA 
chip controls the movement of data between the tape drive and the 
IMSC local RAM. The disk sequencer provides DMA between the disk 
drives and the IMSC local RAM. The IMSC processor (Z8001) uses 
its block move capability to move data from local RAM to or from 
the portion of its memory space which is mapped into the Multibus 
memory space. This is not a true DMA because the initiating 
device (the IMSC processor) stays involved. 

7. MULTIBUS BACKPLANE AND INTERFACE 

Most of the circuits in the P/25 are on PC cards that plug into a 
Multibus backplane. The backplane has 6 slots, and can contain 
one or two memory array boards, three bus masters and a processor 
board. 

The only active circuits on the Multibus backplane are bus 
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priority resolution circuits that arbitrate control of the 
Multibus, and a bus clock generator that provides the 10-Mhz 
signal used by bus masters to synchronize their bus arbiters. 

Each standard-equipped P/25 contains one processor board, one or 
two intelligent communication processors (ICPs) , one or two 
memory array boards (dynamic RAM) and a disk and tape controller 
board. This leaves room one or two user-selectable Multibus 
boards. 

All PC cards except for the memory array are attached to 
connector PI which is described in the IEEE Proposed 
Microcomputer System Sua. Standard ( P796 Standard . The memory 
array boards attach to connector P2 and the diagnostic console 
attaches to connector P3. 

In the P/25, the CPU acts like a bus master. The IMSC and the MMU 

(physically located on the processor board) act like bus masters 

or slaves. User-selectable boards may be either masters, slaves 
or both. 

The P/25 Multibus uses a subset of the parallel arbitration 
technique described in the P736 Standard . 

section 2.4.2.2. Once a master is granted control of the 
Multibus, it maintains control by holding the BUSY/ line active. 
The amount of time a master is allowed to hold the Multibus has a 
serious effect on system performance and can be adjusted. 

The bus priority out (BPRO/) and common bus request (CBRQ/) 
signals are not used by the P/25 standard units, but may be used 
by user-selectable I/O controllers. 



8. POWER SUPPLY 

The P/25 is equipped with a multiple-output, switching power 
supply which provides overvoltage and short-circuit protection. 
It supplies the following levels: 

Volts Amps. 



+ 5 


at 


25 


+12 


at 


2.5 


-12 


at 


1.7 


+24 


at 


4 


-5 


at 


1 
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9. RESET, POWER FAIL AND RESTART 

The entire P/25 can be reset by asserting the INIT/ line on the 
Multibus. This line is controlled by three sources: 

(1) front-panel reset button 

(2) a control bit that can be set by the CPU 

(3) the power supply's AC line monitoring circuitry. 

The AC line monitor sends a power fail interrupt (PFIN/) to all 
devices on the Multibus when the line voltage drops below 
specification. The CPU responds to this interrupt and, after 
performing some housekeeping, resets the system by asserting the 
INIT/ line. Other processors in the system can use the PFIN/ 
internally. 

When AC power is restored to the system, no effort is made to 
restart the system to its state prior to power failure because 
there are no provisions to save the contents of memory during the 
outage. Instead, when failure due to a power outage cannot be 
tolerated, an uninterruptible supply (UPS) for the AC line is 
available. 

NOTE: The P/25 power supply is equipped with brownout 
protection, which provides uninterrupted power to the P/25 for 
16 milliseconds in the event of a transient AC power failure. 

When power is applied to the system, the INIT/ line is asserted 
for about 100 milliseconds. This assures that DC power is stable 
before the system is placed in operation. 

10. STANDARD PERIPHERAL CONFIGURATION 

The IMSC supports a number of industry-standard disk and tape 
drives, so it is possible to configure a wide variety of systems. 
However, the combination of a fixed Winchester disk and streaming 
cartridge tape drive has proven to be a very flexible and cost- 
effective combination, and is therefore offered as the standard. 

10.1. Disk Drive 

The P/25 comes equipped with one of three standard 8-inch fixed 
Winchester disk drives. These are compared in the following 
table: 
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Storage Capac i ty Average Positioning xims. 

(Head Positioning + Latency ) 

22 megabytes 38.55 milliseconds 

36 megabytes 38.55 milliseconds 

72 megabytes 28.3 milliseconds 

Up to 3 additional disk drives may be added in a separate 
cabinet. The total disk capability is 336 megabytes. 

(For further information on the drive, see the Plexus Winchester 
Disk Manual for the appropriate size disk drive. 

10.2. Tape Drive 

The P/25 comes equipped with a 20M-byte streaming cartridge tape 
drive. It has 8000 bpi storage density on 8 tracks, and can 
store 20M-bytes in 3.7 minutes. 

(For further information on this drive, see the Plexus Cartridge 

11. SPECIFICATIONS 

The P/25 with its standard peripherals is packaged in a 19-inch 
wide, 24-inch deep, 10.5-inch tall tabletop cabinet which can fit 
in a standard 19-inch RETMA rack. 

11.1. Processor Specifications 



95 - 130 volts AC @ 4a 
190 - 250 volts AC § 2a 



EhxAxqi 



temperature: 5C to 38C (41F to 100F) 
relative humidity: 20% to 80% noncondensing 
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Overview 



Plexus Computers Inc p/25 ENGINEERING MANUAL 



PROCESSOR 



1. Z8001A MICROPROCESSOR 

2. MEMORY MANAGEMENT UNIT 

3. LOCAL PERIPHERALS 

4. MULTIBUS INTERFACE 

5. LOCAL BUS ARBITER AND TIMING SEQUENCER 

6. ERROR HANDLER 
Figures 
Schematics 



Plexus Computers Inc p/25 ENGINEERING MANUAL 



1. Z8001A MICROPROCESSOR 

The P/25 CPU is built around the Zilog Z8001A 16-bit 
microprocessor. Nearly all features of the Z8001A are used, 
including separate instruction and data space, user/system modes, 
and nonvectored and vectored interrupts. 

The Z8001A in the P/25 has 16 general-purpose registers and 110 
distinct instruction types. For detailed descriptions of the 
registers and instructions, refer to the zilog Z800Q CPU 
Technical uanual. 

The functional blocks on the processor board are shown in Figure 
1. All block references in this section are to Figure 1. 

1.1. Programming Information 

The following programming information is necessary to understand 
the functioning of the Z8001A CPU: 

(a) Address Spaces — All four address spaces provided by 
Z8001A are used in the P/25. The normal I/O space is used to 
communicate with I/O ports on the Multibus. The special I/O 
space is used to control the peripheral circuitry on the 
processor board. Memory instruction and data spaces are used 
to access the corresponding locations in main memory. 

(b) User and System Process — When a user process is 
running, the Z8001A is always operated in normal mode and 
unsegmented mode. But when a system process is running, the 
Z8001A operates in system mode and either unsegmented mode or 
segmented mode. Thus, user programs can only access one memory 
segment but system programs can access all memory segments. 
One segment occupies 64K bytes of address space in Z8001A. 

(c) Data Types — The Z8001A supports manipulation of eight 
data types. Each data type is supported by a number of 
instructions which operate upon it directly. These data types 
are: 

Bit 

Binary integer 

Logic value (boolean) 

Address 

Decimal integer 
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String of bytes 
String of words 
Stack of words 

(d) Byte and Word — Both byte and word operations are 
provided, enabling the Z8001A to transfer data to an 8-bit 
master on the Multibus and enabling a Multibus master to 
access the 16-bit memory system. 

(e) Segments — There are 128 segments available in the 
Z8001A memory address space, providing a maximum address space 
of 8M bytes. In the P/25, the top segment (seg 127) is 
allocated to the memory mapper to reduce overhead when 
swapping processes. The lower segment (seg 0) is allocated to 
the local CPU memory (EPROM and static RAM) . 

1.2. Hardware Interface 

The following Z8001A lines control peripheral hardware functions: 

(a) Address/Data lines — These 16 address/data lines are 
connected from the Z8001A to the local multiplexed 
address/data bus and through it to the other local buses. 

(b) Segment lines (SNO to SN6) — In addition to their normal 
function, the least significant segment line (SNO) is ORed 
with ST2 to select either program or data address space. 

(c) WAIT/ — This line is pulled low, extending the 
transaction time, when any of the following occurs: 

1) EPROM and static RAM read or write 

2) Multibus I/O port read or write 

3) Byte write to dynamic RAM. 

(d) Segment Trap — A segment trap is generated by the error 
handler when a memory mapping error or a EDC error output is 
detected. 

(e) Nonmaskable Interrupt (NMI) — This input is connected to 
POWER FAIL line on the Multibus. 

(f) Nonvectored Interrupt (NVI) — This input is reserved for 
diagnostics and is provided on connector P3. 

(g) Vectored Interrupt (VI) — Two Intel 8259A interrupt 
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controllers (one master and one slave) provide 15 levels of 

interrupt. 

(h) Multi-Micro (MO/) — This Z8001A output pin controls the 
error detection and correction (EDO single-bit interrupt 
circuits. 

NOTE: The MO/ output is not used in earlier models of the 
processor unit. 

(i) STOP/, BUSRQ/ — Not used. 



1.3. I/O Access 



1.3.1. Standard I/O Space 

When a standard I/O instruction is to be executed, the Z8001A 
requests control of the Multibus through the local bus arbiter. 
When control is granted, the CPU places the I/O port address on 
ADRO to ADR15, and asserts the proper read or write control line 
(IORC/ or IOWC/) . The addressed multibus port executes the 
command and returns an acknowledge (XACK/) . The Z8001A allows 
the command execution to complete, then releases the Multibus. 
The proper number of wait-states are inserted automatically when 
standard I/O instructions are executed. 

The CPU uses only word instructions when accessing Multibus ports 
(BHEN/ must be low) . If the port supports only byte operations, 
the high-order byte is undefined when the port is read and 
ignored when the port is written. 

The CPU can maintain control of the Multibus between I/O 
instructions by setting bit Al of the control port PIO (7F88H) 
high. This causes the bus arbiter to hold the bus until the bit 
is reset. Until then, no other bus masters can use the bus. 
This is used primarily for diagnostic fault isolation and to test 
and set shared resource semaphores. 

1.3.2. Watchdog Timer 

A watchdog timer forces the completion of a CPU-initiated I/O 
cycle if the CPU does not receive XACK/ within 20 microseconds. 
This prevents the system from being disabled if the CPU executes 
a standard I/O instruction to a nonexistent port or if the device 
at the port fails to return XACK/. If the timeout occurs, a 
vectored interrupt is sent to the CPU, which must clear the 
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interrupt by performing a special output (SOUT) to port 7FB3H. 

1.3.3. Special I/O Space 

The Z8001A special I/O space is used to control local (processor 
board) peripherals, and for diagnostic and housekeeping 
functions. As with the standard I/O space, only word 
instructions are allowed. For more information on the uses of 
special I/O space, see the Processor section 3, Local 
Peripherals. 

1.4. Trace Mode Capability 

To aid in software debugging, the CPU has trace mode capability, 
which generates a vectored interrupt to the Z8001A when the CPU 
fetches the first word of an instruction in normal mode. This is 
useful for single-stepping through programs. This interrupt must 
be reset by performing an SIO write to port 7FB2H. To shut off 
the trace mode, the CPU must mask off the trace mode interrupt in 
the interrupt controller. 

1.5. Controls and Indicators 

The processor board is equipped with four DIP switches. Three of 
the switches select the baud rate for the diagnostic console and 
the fourth selects automatic boot mode (the system re-initializes 
itself automatically after powerup or reset) . 

NOTE: The switch and LED functions are set by system software 
and are subject to change. 

The processor board also has four LEDs (CR4 to CR7) which provide 
diagnostic information during powerup and system status 
information during normal operation. The LEDs indicate system 
status as follows: 

CR 4 — ON indicates a disk access 

CR 5 — ON indicates a tape access 

CR 6 — Not used 

CR 7 — ON indicates user access. 
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1.6. Circuit and Timing Analysis 

A basic timing diagram of the Z8001A for both read and write 
operations is shown in Figure 2. 
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2. MEMORY MANAGEMENT UNIT <MMU) 

The MMO is physically located on the processor board. Its basic 
functions are: a) to map logical address space into the physical 
address space and b) to check each memory reference for 
consistency with the attribute bits assigned to each page. 

2.1. Memory Mapping 



2.1.1. Address Mapping Scheme 

Address mapping allows the P/25 to distinguish between logical 
and physical memory addresses. A physical address is an actual 
location in the memory array. A logical address is a location 
within a program whose physical address is relative to the 
physical address at which the program started. For example, 
logical address 132 in a program stored beginning at physical 
address 16000 is at physical address 16132. 

The page mapper acts like a file clerk, placing logical files in 

physical locations and remembering where they are located. All 

programs and processes are mapped; the only direct access of 

physical memory occurs during powerup. 

When the Z8001A is accessing memory, the lower five segment lines 
(SNO to SN4) and the five highest offset address lines (A15 to 
All) are input to the page map RAM, which produces the 12 high- 
order bits of the physical address. The lower five segment lines 
select one of 3 2 page maps, and the high five offset address 
lines select pages within the map. Each map contains from one to 
32 pages, and each page contains 2K bytes of memory. The address 
within each page is selected by the lower 11 offset address lines 
(A0 to A10) , which are unchanged by the page-mapping process. 

The lowest segment line (SNO) is ORed with the Z8001A 
instruction/data line (ST2) , so that while in instruction mode, 
only odd-numbered map sets can be accessed. This way, a program 
running in unsegmented mode (i.e. a system program) can access a 
user program but a user program cannot change a system program. 
This allows several user programs to use the same system program 
without being able to change it. 

The Multibus accesses memory through the Multibus map RAM, which 
can select one of eight page maps. The output of the Multibus 
map RAM is used in place of the segment lines (and I/D bit) as 
input for the page map RAM. 

Both arrangements are shown in Figure 3. 
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A typical process or program requires two map sets; one pointing 
to instructions and one pointing to data. The minimum memory for 
a single program is 4K bytes and the maximum is 128K bytes (2K to 
64K for instructions and 2K to 64K for data) . Up to 16 processes 
can be resident in memory simultaneously. 

Several processes can execute the same program simultaneously. 
When this occurs, they share the same physical instruction space 
but each has its own data space and its own map set. Each map 
points to the same instructions in physical memory and to a 
separate data space in physical memory. 

2.1.2. Powerup And Reset 

When the P/25 is powered-on or reset, the MMU is disabled and 
physical memory addresses are generated by concatenating sixteen 
Z8001A address lines to the seven segment lines. This is required 
since the Z8001A starts loading the program counter and control 
word from address 2 in segment 0. 

2.1.3. Programming Information 

Before enabling the MMU, the Z8001A must load the page map RAM 
using either special I/O instruction or memory instructions. The 
page map appears as 1024 contiguous 16-bit ports which can be 
read or written using special I/O instruction. These ports are 
located at even addresses from 8000H to 87FEH. The same map 
location can also be addressed as 1024 contiguous word memory 
locations between 8000H and 87FEH in segment 127. Logically, 
these addresses can be thought of as 32 map sets each containing 
32 pages, as shown in Figure 4. 

Like the page map, the Multibus map must be loaded by the Z8001A 
before any controllers can access memory through the MMU. This 
map appears as eight contiguous 8-bit special I/O ports from 
FF88H to FF8FH. The format of the Multibus map is shown in Figure 
5 . 

After the Multibus map has been loaded, the CPU enables the map 
by performing a special output to port FF90H. 

The Z8001A can prevent Multibus controllers from accessing memory 
by writing to port FF98H. However, this is not necessary when 
the Z8001A is changing the page map or the Multibus map. 
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2.2. Memory Protection 

The MMU checks each memory reference to ensure that it is 
consistent with the attribute bits assigned to the page. Each 
page can be assigned a read-only and an invalid status. If a page 
has its read-only bit set, the Z8001A or Multibus controllers 
cannot write to that page. The invalid bit indicates that the 
page is not resident in physical memory. In the event of an 
illegal memory reference, the action taken by the MMU depends on 
the current memory cycle and map attribute bits as follows: 

Z8001A=0 S=0 

Multibus=l h=i 





R-l 

h=o_ 


Read 

Only 


Page 
Invalid 












1 


Generate 
trap 


segment 





1 


1 


Generate 
trap and 
write 


segment 
inhibit 


1 


- 


1 


Generate 
trap 


segment 



10 10 Generate segment 

trap and inhibit 
write 

10 1 Generate segment 

trap 

10 11 Generate segment 

trap and inhibit 
write 

11 1 Generate segment 

trap 

110 10 Generate interrupt 

and inhibit write 

110 1 Generate interrupt 

110 11 Generate interrupt 

and inhibit write 

111 - 1 Generate interrupt 
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If the illegal reference was generated by the Z8001A, the MMU 
asserts the Z8001A segment trap line. If the violation was caused 
by a Multibus controller, the MMU sends a vectored interrupt 
(MMUINT) to the Z8001A. Both are handled by the error handler 
(block 43) . 

When a memory violation occurs, the following information is 
stored in latches that can be read by the CPU: 

(a) Address and map set numbers which caused the violation 

(b) Status information 

(c) The address of the first word of the last instruction 
fetched before the error occurred (Z8001A violations only) . 

Subsequent errors do not update these latches until the Z8001A 
resets the error condition by performing a write to port FFAOH. 
The format and address of this information is shown in Figure 11. 

2.3. MMU Circuit Analysis 

The MMU is shown in Figure 1 as blocks 3, 4, 8, 9, 13, 14, 15 and 



2.3.1. Normal Operation 

The lower five segment lines and the highest five offset address 
lines are input to the page map RAM, where they select a page map 
entry. The page map RAM outputs a 12-bit physical memory address 
which passes through the buffer in block 15 to reside on 
connector P2. The offset address passes through block 14 to also 
reside on connector P2. During normal operation (in map mode), 
blocks 14 and 15 are enabled and block 13 is disabled. During 
reset (nonmap mode) , block 13 is enabled and the physical address 
passes to connector P2 without changing. 

NOTE: The 11-bit offset leaves block 4 with only 10 bits. 
The 11th (low-order) bit is always a zero, which places it on 
a word boundary. 

2.3.2. Loading and Reading the Page Map RAM 

The page mapper is a high-speed static RAM with 55-nsec access 
time. 

When the Z8001A wants to load or read the page map RAM, it issues 
a memory reference to segment 127. The memory address decoder 

2~4 Processor 



Plexus Computers Inc 



P/25 ENGINEERING MANUAL 



(block 39) generates a SEG127 si 
which prevents the local bus ar 
memory cycle won't be started.) 
controller (block 10) decodes 
the PGMAPIOSEL/ signal (U166 pin 
mapper are selected and a read o 
The MMU controller is responsibl 
and CYCENDI07 (sh 9) . CYCENDIO/ 
local bus arbiter. 



gnal (active high, U152 pin 10) 
biter from pulling MEMRQ/ low. (A 
Instead, the peripheral interface 
the offset address and generates 
6) . The static RAMs in the page 
r a write operation is performed, 
e for generating WE2148/ (sh 20) 
signals the end of a cycle to the 



When the page mapper is accessed as special I/O ports, the above 
sequence is the same except that the SEG127 signal stays inactive 
(LOW) . 

The Multibus mapper is a high-speed bipolar RAM inverting memory 
(74S189) which must be loaded with complemented (inverted) data. 
The Z8001A can only write to the Multibus map; the contents in 
the Multibus map are not readable. The MMU controller generates 
WE189/ (sh 20) , CYCENDIO/ (sh 9) and the peripheral interface 
controller generates MBMAPCS/ (sh 9) to perform a Multibus map 
write operation. 

2.4. Address Latches and Bidirectional Data Buffers 

Four local buses are provided on the processor board. These are 
the: 

(a) Multiplexed Address/Data Bus (MA/D) — Passes data 
between the Z8001A and the other local buses through the 
buffers in blocks 3, 4, 5 and 7. 

(b) Local Peripheral Bus — Passes data between the 
peripheral devices on the processor board and the MA/D bus. 

(c) Local Address Bus — Passes data between the MMU, local 
memory and system memory. These leave the board in two 
groups; PADR to PADR 9 and PADR A to PADR 15. 

(d) Local Memory Data Bus — Passes data between the MA/D bus 
(through buffer block 5) , the page mapper (block 8) and the 
Multibus data lines (DAT to DAT F) or the system memory data 
lines. 

All address lines from the multiplexed address/data bus to the 
other local buses are latched at the trailing edge of AS/. 
Blocks 3 and 4 latch the logical segment lines and offset address 
lines from the Z8001A. Block 6 latches the I/O port address to 
select local peripherals. Block 5 contains the 16-bit 
bidirectional buffers between the multiplexed address/data bus 
and the local memory bus. These communicate between the Z8001A 
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and system memory (or the Multibus) . Block 7 contains the data 
buffers to communicate with peripherals on the processor board. 

2.5. Wait-State Generator 

Whenever a Z8001A read/write cycle cannot be completed within a 
period of three clock cycles, the wait-state generator (block 40) 
pulls WAIT/ line LOW and inserts a proper number of wait-states 
to finish the cycle. In the Z8001A, I/O transactions are at least 
four clock cycles long. The wait-state is not inserted when local 
peripherals are being accessed. The number of wait-states 
inserted for different types of Z8001A cycles are listed below: 

EPROM and static RAM read or write 1 

Byte write to dynamic RAM 1 

Multibus I/O port read or write 20 usee max 

2.6. Status Latches and Decoder 

The read-write (RW/) , byte-word (BW/) and system-normal (SN/) 
control lines are latched by the status latch decoder (block 2) . 
It also decodes the status lines (STO to ST3) to generate the 
following signals: 

DATAMEM — Data memory 

STDIO — Standard I/O 

SPECIO — Special I/O 

VIACK — Vectored interrupt acknowledge 

SEGTRAPACK — Segment trap acknowledge 

2.7. Memory Access Arbitration 

The local bus arbiter receives requests for main memory from the 
CPU through the CPUREQ line (see the processor schematics, page 
17, U55, pin 6), from Multibus controllers through the MBREQ line 
(see the schematics, page 12, U105, pin 5) and for refresh from 
the REFREQ line (see the schematics, page 20, U101, pin 9). On a 
first-come-first-served basis, the arbiter asserts the grant line 
(ZGRANT, MBGRANT or REFGRANT) to the winning device. When 
requests from two different devices are received, the arbiter 
interleaves the GRANT outputs in the following order: Z8001A, 
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refresh and Multibus. 
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3. LOCAL PERIPHERALS 



3.1. Introduction 

The peripherals on the processor board include a parallel 
input/output controller (Z80-PIO) , a counter/timer circuit (Z80- 
CTC) a realtime clock, a master and slave programmable interrupt 
controller (PIC) and a diagnostic port (USART) . The board also 
includes four LEDs and a selector switch (4 STSP DIP) . 

NOTE: Older processor boards (4-Mhz) are equipped with a 
floating-point processor. This has been replaced with 
software on the newer (5-Mhz) boards. 

All local peripherals communicate with the Z8001A via the local 
peripheral bus and are addressed as ports in the Z8001A special 
I/O address space. The port addresses (in hexadecimal) are as 
follows: 



PIO 

CTC 

Realtime clock 

Master PIC 

Slave PIC 

USART 

Status Switches 



— 7F88 to 7F8F 

— 7F80 to 7F87 

— Controlled by PIO 

— 7F90 to 7F97 

— 7F98 to 7F9F 

— 7FA0 to 7FA7 

— 7FA8 to 7FAF 



3.2. Peripheral Interface Controller 

The peripheral interface controller generates chip-select signals 
and control logic for various peripheral devices on the processor 
board. It is actually a collection of chips, most of which are 
shown on page 9 of the processor shcematics. It appears in 
Figure 1 as block 10. 

The peripheral interface controller reads the address/data lines 
(ADO to ADF) and the AS/ and DS/ signals from the Z8001A. When 
it sees the address of a chip under its control, it generates the 
proper chip-select signal (SEL) , using the AS/ and DS/ to ensure 
proper timing. 
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It uses the R/W signal from the Z8001A to generate RDZ80/ which 

causes the CTC, PIO and USART to read when it goes low. It also 

generates IORQZ80/ which the CTC and PIO use for their IORQ/ 
inputs. 

The following table shows the chip-enable signals and the devices 
they control: 

P_e_vic£ Signal 

CTC CTCSEL 

PIO PIOSEL 

Master PIC 8259MASTSEL 

Slave PIC 8259SLVSEL 

USART U ARTS EL 

Status Latches STATUSOSEL to STATUS3SEL and STATWSEL 

Multibus Map MBMAPSEL 

Page Map PGMAPIOSEL 

Error Detector (EDO 2960SEL 

3.3. Parallel Input/Output (PIO) Controller 

The Z8001A controls various local functions through the PIO chip. 
The PIO has three 8-bit ports. One port communicates with the 
Z8001A through the local peripheral bus. The other two ports (A 
and B) connect to the devices controlled by the PIO. 

Port A is set for output only; the PIO receives instructions from 
the Z8001A and outputs the data it receives on Port A. Port B is 
programmed for input and output; the PIO receives instructions 
from the Z8001A and outputs them on port B f but port B also 
receives data and outputs it to the Z8001A. The port 
assignments are shown in the following table: 

NOTE: Port A and B pin assignments are shown on page 6 of the 
processor schematics. 
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210. Port A. Mt 


I/O 


Function 




Active Level 








Software Reset 




Low 


1 





Multibus Lock 




High 


2 





Enable Memory 


Map 


Low 


3 





Enable Error Handler Trap 


Low 


4 





MSM5832 Hold 




High 


5 





MSM583 2 Head 




High 


6 





MSM5832 Write 




High 


7 





Z8001A Reset P 


rotect 


Low 



NOTE: The MSM5832 is the CMOS calender clock chip described in 
part 3.4. of this section. 



Function Acti ve Level 

MSM583 2 Data and LED Low 

MSM583 2 Data 1 and LED 1 Low 

MSM583 2 Data 2 and LED 2 Low 

MSM583 2 Data 3 and LED 3 Low 
MSM583 2 Address n/A 

MSM583 2 Address 1 n/A 

MSM583 2 Address 2 N/A 

MSM583 2 Address 3 N/A 



Port B, bits through 3 serve a double purpose: they take data 
from the realtime clock and output it to the Z8001A, and they 
take data from the Z8001A and output it to the status LEDs. When 
they are outputting data to the LEDs, the MSM583 2 HOLD line is 
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activated. For more on the status LEDs, see Processor section 1. 

3.3.1. Programming Information 

To control each PIO output port, the Z8001A must write two 
instructions. The command instruction determines the mode in 
which the port operates, and the data instruction supplies the 
output data. Port A is set to operate in mode (output mode) , 
and port B is set to operate in mode 3 (control mode) , because it 
transfers data in both directions. 

Each instruction goes to a unique port address within the PIO 
address space as follows: 

Port A Command 7F8A 

Port A Data 7F88 

Port B Command 7F8B 

Port B Data 7F89 



See the Zllog. 1981 Data Book . "Z80-PIO Product Specification" for 
additional information. 



3.3.2. I/O Bit Definition 

The following PIO lines require special attention: 

Port A, Bit (Software Reset) — The CPU can reset the whole 
system by pulling this bit low. 

Port A, Bit 7 (Z8001A Reset Protect) — This bit works with 
the above bit. If this bit is set low, a software reset 
clears all I/O boards on the Multibus, but not the processor 
board. 

Port A, Bit 2 (Enable Memory Map) — When this bit is low, the 
Z8001A runs in mapped mode. 

Port A, bit 3 (Enable Error Handler Trap) — When this bit is 
inactive (high) , the circuit which generates the segment trap 
for memory mapping errors or EDC errors is disabled. 

Port A, Bit 1 (Multibus Lock) — After powerup or reset, 
Multibus controllers are not allowed to access the memory. The 
Multibus access is permitted only after this bit is set 
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(active LOW) . 



3.3.3. Counter/Timer Circuit 

The CPU uses a four-channel counter-timer (Zilog Z80B CTC) to 
provide realtime interrupts to the Z8001A. The ZC/TOO output 
(channel 0) is connected to the CLK/TRG input of channel 1. The 
ZC/TOl output (channel 1) divides the system clock down to 50 hz. 
It is used to trigger a flip-flop (U123) which asserts the 
CTCINTR (active HIGH) to cause the interrupt. 

The Z8001A resets the interrupts by performing a special I/O 
write to port 7FB1. 

Each Z80-CTC channel must be programmed by the Z8001A prior to 
operation. It writes two 8-bit words to the desired channel over 
the local peripheral bus. The first word is the channel control 
word which sets the operating mode for the channel. The second 
word is the time constant (see the Zilog 1981 D_a_£a. Book , "Z8430 
CTC Product Specification") . The channel control word for 
channel consists of the following: 

Identifies the control word 

Software reset enabled 

Time constant follows 

Timer is triggered automatically when 
time constant is loaded 

Falling edge triggered 

Prescaler value = 16 

Timer mode 

Interrupt disabled 

Channel 1 is programmed the same as channel except that it 
operates in counter mode (D6 is set to 1) . 

3.4. Realtime Clock 

A clock calendar gives the CPU access to the time of day in 
hours, minutes and seconds, and also to the day, month and year. 
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This battery-operated circuit has its own crystal oscillator and 
remains running even when AC power is removed. The battery is 
automatically charged whenever the system is operating. It powers 
the clock for three months between charging. 

The clock calendar function is provided by a MSM583 2 CMOS clock 
circuit. This circuit inputs its data to the PIO, which passes it 
to the Z8001A over the local peripheral bus. Its address, data 
and control lines are listed in the Processor section, part 3.2. 

Figures 6 and 7 show the PlO/realtime clock circuit read/write 
timing requirements (see QE1 Semicnn<1iiRhn r MSM5B32 Microprocpssnr 
fifialiime £las_k7 Calender Product Specific ation) . 

3.5. Programmable Interrupt Controller (PIC) 

The vectored interrupt structure in the P/25 is handled by two 
Intel 8259A PICs. One functions as the master PIC, the other the 
slave PIC. The master PIC (page 14, U106) accepts interrupt 
requests from onboard peripherals. The slave PIC (page 14, U107) 
accepts interrupt requests from Multibus I/O controllers. 

The basic functions of the PICs are to: a) accept interrupt 
requests, b) determine the priority of interrupt requests, c) 
assert a vectored interrupt to the Z8001A based on priority and 
d) provide the interrupt vector to the interrupt service routine. 

In the P/25, there are 14 levels of interrupt priority, assigned 
as follows: 
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MASTER PIC 



Priority 



High Unused 

1 Multibus watchdog timer 

2 CTC clock 

3 Multibus MMU error 

4 Unused* 

5 Trace, normal address space 

6 USART interrupt 

Low 1 Cascade from slave PIC 

* In older (4-Mhz) systems, priority 4 is assigned to the floating 
point processor. 

SLAVE PIC 

Pr i ority , Function 

Hi gh Multibus interrupt (INTO/) 

1 " (INT1/) 

2 " (INT2/) 

3 " (INT3/) 

4 " (INT4/) 

5 " (INT5/J 

6 " (INT6/) 

Multibus interrupt (INT7/) 



Low 7 



*S3 "Programming Information" The Intel 8259A PIC requires 
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initialization programming before it can process interrupt 
requests. The initialization sequence involves two to four byte- 
writes to each PIC. In the P/25, the initialization command words 
(ICWs) are issued as shown in Figure 8 (see the Intel 8259A 
Programmable, xniejirupj; Controller Product specification ) . 

Since the PIC is not programmed in the automatic-end-of-interrupt 
(AEOI) mode, each individual interrupt service routine is 
required to issue a nonspecific end-of-interrupt command to clear 
the in-service bit in the corresponding Pic. 

3.5.1. Circuit Analysis 

The vectored interrupt cycle proceeds as follows: 

A local peripheral device or a Multibus master requests an 
interrupt by asserting an interrupt line on one of the PlCs. 

The PIC determines the priority of the interrupt (see 
interrupt priority table above) . 

The PIC asserts the Z8001A VI/ line. 

The Z8001A waits until it reaches an interruptable point, then 
starts an interrupt cycle by sending the proper status to the 
status latch decoder (block 2) , which sends VIACK/ to the 
interrupt acknowledge handler (block 42) . 

The interrupt acknowledge handler outputs the first INTA/ 
pulse, which lasts for one clock cycle. This pulse causes the 
PIC to freeze the state of priority resolutions and causes the 
master PIC to issue an interrupt code to the slave. 

"The second INTA/ pulse, which is actually a copy of the DS/ 

signal from the Z8001A, causes the PIC to output the interrupt 

vector on the local peripheral bus. This is the end of the 
PIC's involvement. 

The Z8001A reads the vector on ADO to AD8. It goes to the 
vector indicated and executes the instructions there. 

The high five bits of the 8-bit vector are common to all eight 
interrupt request lines on a given PIC. They define a memory 
location where an interrupt instruction table is located. The 
lower three bits carry the code (0 to 7) for the interrupt. 
These bits define the table entry specific to each interrupt. 

Since the Z8001A requires all vectors to be on even boundaries 
(bit must be zero) , the PIC lines are shifted one bit, so that 
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data line from the PIC connects to data line 1 of the local 
peripheral bus; PIC line 7 connects to peripheral bus line 8. 
Data line is only pulled LOW during an interrupt acknowledge 
cycle. This has the effect of placing the interrupt vector 
produced by the PIC on an even boundary. It also implies that 
when the PIC is read or written, the data must be shifted one bit 
to the left. 

3.6. Diagnostic Port 

The diagnostic console is supported by an industry-standard 
RS232C port (USART) attached to connector P3. The following 
table shows the EIA RS232C pins supported when a terminal is 
connected to P3. (If a modem is attached, the pins are identical 
to the ICP SIO pins — see the Input/Output Controller section in 
this manual) : 



RS 232C £in l/Q 



Name 



2M1 P_in 



Function 



TxD 



RxD 



RxD 



TxD 



Serial data from 
terminal 

Transmitted data from 
diagnostic port 

General purpose input 

General purpose output 

General purpose input 

General purpose output 

General purpose input 

Signal ground 

Protective ground 

♦These pins must be enabled (held high) for the UART to operate. 

This connector is set up to connect directly to a terminal; data 
modems require a null modem cable. 

The diagnostic (console) port consists of a Signetics 2661 
enhanced programmable communication interface (EPCI) and RS23 2C 



20* 


I 


DTR 


DSR 


6 





DSR 


DTR 


8 


I 


DCD 


DCD 


5 





CTS 


RTS 


4* 


I 


RTS 


CTS 


7 


- 


Ground 


- 


1 


- 


Ground 


_ 
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transceivers. The EPCI is a universal synchronous/asynchronous 
data communication controller chip which can support various 
communication protocols. It contains a baud rate generator which 
can generate 16 different baud rates between 50 and 19,200 baud. 
The 2661 EPCI's TxRDY (Transmitter Ready), RxRDY (Receiver Ready) 
and TxEMP (Transmitter Empty) interrupt lines are all ORed 
together to create a single vectored interrupt to the Z8001A. 

The diagnostic terminal baud rate is selected by three of the 
switches described in the Processor section, part 1.5. 

3.6.1. Programming Information 

The port addresses assigned to the registers in the 2661 EPCI are 
as follows: 



£oj:t Addxe^a Function 

7FA0H Data holding register 

7FA1H Status register 

SYN1/SYN2/IDLE registers 

7FA2H Mode register 1 

7FA2H Mode register 2 

7FA3H Command register 
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4. MULTIBUS INTERFACE 



4.1. Introduction 

Most P/25 system components communicate with each other over the 
Multibus backplane, which occupies connector PI. The exceptions 
are the memory boards (dynamic RAM), which occupy connector P2. 
Refer to the 1E£E Proposed Microcomputer System Bji£ Standard 
(P796 fiiia) for a more complete description of the Multibus. 

The processor board can act as a Multibus master or slave. As a 
master it can access up to 64K 16-bit ports in the standard I/O 
address space. As a slave, it occupies the upper half of the 
Multibus logical address space. 

The Multibus interface can handle both byte and word transfers on 
the Multibus. 



4.2. Multibus Memory Access 

The timing diagram for the Multibus memory access is 
Figure 9. 



shown in 



A Multibus memory r 
significant address 
MWTC/) are activated 
logic to generate th 
page 12) asserts a r 
The local bus arbi 
served basis by asse 
31. A memory cycle 
Memory section. 



equest is recognized when both the most 
line (ADR 13/) and the control line (MRDC/ or 
by a Multibus master. Block 33 contains the 
e MBREQ signal (see the processor schematics, 
equest for local bus on the processor board, 
ter grants the request on a f irst-come-f irst- 
rting MBGRANT/, which enables blocks 30 and 
is started as discussed in this manual in the 



In a Multibus read cycle, data read from the memory is latched 
into U31 and U52 when the CYCEND/ is asserted. The processor 
board can start the next memory cycle or onboard I/O cycle 
without waiting for completion of the Multibus cycle. The XACK/ 
is asserted on the Multibus (sh 12, U136 pin 5). The Multibus 
master removes the MRDC/ or MWTC/ command. This ends a complete 
Multibus cycle. 

4.3. Processor Board Multibus Access 

The timing for the processor board Multibus access is shown in 
Figure 10. 

The processor board accesses the Multibus controllers as I/O 
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ports in the Z8001A standard I/O address space. The access 

starts when the IORQMB signal (page 9) goes active (HIGH) . The 

IORQMB signal is generated at the rising edge of AS/ when a 

standard I/O instruction is executed. The synchronization of 

IORQMB and BREQ/ (Multibus signal) is achieved by flip-flop U173 
(sh 10) . 

The Multibus exchange priority logic is located on the backplane. 
Priority is resolved in a parallel fashion whereby each slot on 
the backplane has a fixed Multibus access priority. This 
results in a location-dependent priority scheme. 

If the Multibus is free (BUSY/ = high) , a Multibus I/O cycle can 
be initiated immediately. Otherwise, the processor board waits 
until the current Multibus master relinquishes control of the bus 
(BUSY/ goes high) . When this happens, J-K flip-flop U171 (sh 10) 
pulls the BUSY/ line low, locking out other Multibus masters. 
The MBIOENAB signal notifies the CPU that the Multibus has been 
granted. It also enables the data and control buffers (blocks 34 
and 36) connected to the Multibus. A Multibus timer starts and 
the buffers output the address of the Multibus slave to be 
accessed. 

When the slave responds by pulling the XACK/ line low, it sets a 
flip-flop (U176 — processor schematics, page 10) which pulls 
the WAIT/ line high. The Z8001A leaves the wait-state and 
finishes the cycle. 

If the slave fails to respond within 20 microseconds, the timer 
causes a Multibus timeout interrupt to be generated. The Z8001A 
leaves the wait-state and resets the interrupt by performing a 
write to I/O port 7FB3H. This ensures that the P/25 cannot be 
locked due to a failed Multibus card. 

The trailing edge of DS/ from the Z8001A triggers the end of a 

Multibus I/O cycle. IORQMB, BREQ/, MBIOENAB/, IORD or IOWR/ , and 

address or data go inactive sequentially. The BUSY/ line goes 
high, freeing the Multibus. 
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5. LOCAL BUS ARBITER AND TIMING SEQUENCER 

This section describes the processor board timing logic for the 
local bus arbiter and the timing sequencer. 

In the P/25 processor board, the local address bus and the local 
memory/data bus are shared by the Z8001A, Multibus controllers 
and the refresh circuits. The local bus arbiter is designed to 
handle the sharing of the buses. It arbitrates the buses on a 
first-come-first-served basis for every memory access. If there 
is contention, the priority is assigned in the order: Z8001A, 
refresh and Multibus. The GRANT lines (ZGRANT/, REFGRANT/ and 
MBGRANT/) signal the winning device. 

The timing sequencer is designed to generate the proper timing 
for the different types of memory cycles. For example, the PMREQ 
starts a memory cycle when a mapped physical address is valid and 
the LEIN controls the latching of input buffers in the EDC chip. 

5.1. Local Bus Arbiter 

As shown in the block diagram (Figure 1) , the local bus arbiter 
receives: a) the MBREQ signal from the Multibus select logic 
(block 33) , b) the REFRQ signal from the refresh circuits (block 
26) and c) the AS/ signal from the Z8001A. The one which is 
granted memory access has its corresponding GRANT/ line asserted 
(MBGRANT/, ZGRANT/ and REFGRANT/). These control lines direct the 
flow of data in the processor board. 

The MEMRQ/ and CYCEND/ signals are used to handle handshaking 
between the local bus arbiter and timing sequencer. The MEMRQ/ 
starts a memory cycle and CYCEND/ ends a memory cycle. 

The local bus arbiter controls six different transitions from one 
type of memory access to another. These are: 

Z8001A to Multibus 

Z8001A to refresh 

Multibus to Z8001A 

Multibus to refresh 

Refresh to Z8001A 

Refresh to Multibus 

The memory transition is synchronized by running the local bus 



5-1 Processor 



Plexus Computers Inc 



P/25 ENGINEERING MANUAL 



arbiter with a 20-Mhz clock. 



5.2. Timing Sequencer 

The timing sequencer (block 22) is a bipolar-PROM-based state 
machine. Nine different types of timing programs are stored in 
the PROM. Only one program is executed for each type of memory 
access. Outputs from the timing sequencer control the timings 
required in a read/write cycle. 

The following signals are output from the timing sequencer: 

PMREQ — Asserted when a valid mapped physical address 
is available. 

REFSH — Generated in a refresh cycle. Functionally 
equivalent to PMREQ. 

PREAD — Controls the direction of the data buffers on 
connector P2 for read operations. 

PWRITE — Controls the direction of data buffers on P2 for 
write operations. 



LEIN 
LEOUT 

WE/ 



— Latches data into the EDC buffers. 

— Latches data into the EDC output buffers and 

samples the error/ and multi-error/ lines. 



— WRITE ENABLE strobe generated in a write cycle. 
OE0,l/ — Enables output latches in the EDC chip. 
OESC — Enables output buffers of EDC chip. 
GEN/ — Active when CPU is in a memory write cycle. 
DZEN — Controls the Z8001A data buffers. 
CYCEND/ — Signals the end of a memory cycle. 
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6. ERROR HANDLER 



The error handler (block 43) has two functions. It generates a 
segment trap or a vectored interrupt when errors occur and it 
latches relevant information about the error in the error status 
registers. 

The P/25 detects two kinds of errors on the processor board. The 
first kind, a memory mapping error, occurs when a memory access 
violates the protection bits assigned to a page. The second kind, 
an EDC error, is generated by the EDC chip when the data 
checkbits stored in memory do not match the new checkbits 
generated for comparison during a read operation. 

The operating environment in which a memory mapping error is 
generated and the action associated with the error are discussed 
in Processor section 2 and in Memory section 2. 

6.1. Circuit Analysis 



6.1.1. Memory Happing Errors 

When a memory access violates the attribute bits assigned to a 
page, the ERROR line is pulled low, setting flip-flop U156. If 
the memory access was initiated by a Multibus controller, U170 is 
set and MMUINT is sent to the PIC which generates a vectored 
interrupt. If the access was generated by the CPU, a segment 
trap is generated. The CPU can mask the trap by setting bit 7 of 
PIO port A. 

If the error is caused by a write to a read-only protected page, 
then the write operation is suspended by asserting SUPPRESS WRITE 
(see the processor schematics, page 15) . 

6.1.2. EDC Errors 

When the EDC detects a single-bit error, it corrects it and 
activates the ERROR line to the error handler. When it detects a 
multiple-bit error, it activates the ERROR line and the MUL-ERROR 
line. 

The error handler uses these inputs to generate the proper 
action: a) if the access was initiated by a Multibus master 
(other than the CPU) it sends a MMUINT to the PIC, which 
generates a vectored interrupt, and b) if the access was 
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initiated by the CPU, the error handler sends SEGTRAP to the 
Z8001A, which generates a segment trap. 

Because the EDC corrects single-bit errors, the interrupt (or 
trap) serves to log the error. For multiple-bit errors, the 
interrupt (or trap) prevents incorrect data from being written to 
the requesting device. 

Both error lines to the error handler are sampled at the falling 
edge of LEOUT signal. 

When the P/25 runs in the unmapped mode, the read-only bit and 
page-invalid bit in the page mapper must be cleared to allow the 
error handler to sample the EDC ERROR/ and MULTIERROR/ outputs. 

6.1.3. Error Recovery 



Before the error handler can detect the next error, the flip- 
flops (U156 and U170) must be cleared with a write to special 
port FFAOH. This is also required to enable the error handler 
after powerup or reset. 

6.2. Error Status Registers 

Error status registers located at port addresses FF90H, FF98H, 
FFAOH and FFA8H latch relevant status information when an error 
occurs. The registers latch the address of the memory location 
that caused the error, several status bits that describe the 
access, and a 6-bit syndrome code if the error was generated by 
the EDC. The format and data are shown in Figure 11. 
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Figure 1. P/25 Processor Board Block Diagram — Part A 
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1. ICP OVERVIEW 

The I/O controller is an intelligent communication processor 
(ICP) which handles the interface between I/O devices and the 
CPU, leaving the CPU processor free to execute instructions. 
Each Plexus P/25 can be equipped with one or two ICPs; each ICP 
has connections for 8 serial ports (SIO) and 1 parallel port 
(PIO) . The SIO ports are standard RS232C interfaces and the PIO 
port interfaces a Centronics (type) parallel printer. 

The ICP is a double-height Multibus module that contains a 16-bit 
Z8002 microprocessor. In its memory space it has 32K bytes of 
RAM with parity, 16K bytes of PROM and 16K bytes mapped into 
system main memory. It communicates with the I/O devices through 
nine DMA ports and with the CPU processor through the Multibus. 

The purpose of the ICP is to pass data between system memory 
(RAM) and I/O devices (terminals, printers, disk and tape 
drives) , using DMA to bypass the CPU. The CPU provides 
instructions in the form of pointers to command and status blocks 
located in main memory. The ICP processor fetches the blocks and 
executes the instructions. This arrangement frees the CPU from 
handling typically slow I/O operations. 

The ICP includes buffers to store the data between destinations 
and control logic to access the Multibus, over which all data is 
passed. 

A block diagram (Figure 1) shows the basic organization of the 
ICP. 



1-1 I/O Controller 
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2. PROCESSOR 

The ICP uses a Z8002 (unsegmented) 16-bit microprocessor 
operating at 4.0 Mhz. It is always operated in system mode and 
there is no separation of instruction and data nor of special and 
standard I/O spaces (special I/O space is not used) . The ICP 
processor can directly address 64K bytes of memory. The lower 
48K is resident on the ICP and the upper 16K is mapped into main 
memory via the Multibus and system MMU. 

All three forms of interrupt — nonmaskable, vectored and 
nonvectored ~ are used by the ICP processor to keep informed of 
the ICP activities. Nonmaskable interrupts are only used to 
inform the ICP processor that a memory parity error or power 
failure has occurred. Vectored interrupts are used for a variety 
of purposes. Nonvectored interrupts are used to inform the Z8002 
that it has control of the Multibus. 

The processor and associated logic to interface the rest of the 
board is shown on page 2 of the ICP schematics. Paks U41 and U43 
are bidirectional bus drivers used to drive/receive data into and 
out of the processor. They are active as long as the processor 
has the bus (BUSACK/ nonactive) with direction control cominq 
from TO' CPU, a derivative of the processor's R/W and DS/ signals. 

Paks U57 and U58 are latches used to hold the I/O or memory 
address while data transfer is taking place. These are 
unidirectional latches (out from the processor) which latch the 
address output from the processor (for the SIO, PIO, DMA, PROM 
etc) -Paks U70 and 071 are control bus drivers which provide 
inverted and noninverted drive capability for the processor 
control bus used all over the ICP. Pak U128 generates the 4-Mhz 
clock required by the Z8002, the SIO, PIO, DMA and miscellaneous 
the X Z8002 C nS * Cl ° Ck iS MOS ~ com P atible ' as required by 

lla °™ir d SSS deS fc ?I f °?u Sta ^? lines comin 9 out of the Processor 
a £f- K ! P rov f d f s th e ability to tristate IORQ/ and VIACK/ so 
that the DMA can take over the control bus when it is active 

N0 5? tJ ?™ 5° th U92 and D93 are active onlv when I' BUSACK is not 
active (DMA does not have the bus) . See the Zll&i Z8QQQ cpu 

Techn i ca l Maiwal for complete details of the processor operation 
and timing. 

The ICP has two separate buses going to and from the Z8002. The 
data goes through U41 and U43 , and addresses go through U57 and 
U58. These are shown on page 2 of the ICP schematics, and in 
Figure 1. 
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3. LOCAL MEMORY 

The ICP contains 32K bytes of dynamic RAM composed of two 16K- 
by-9 banks (including parity) , from location 4000H to BFFFH. The 
memory is organized as shown on page 4 of the ICP schematics. 
The RAM chips are U5 to U13 and U22 to U29. 

Refresh is controlled by the ICP processor. Parity generation and 
checking can be enabled or disabled by the processor. A parity 
error sets a latch (U86) and generates a nonmaskable interrupt to 
the processor. The parity latch can be read by the processor 
using I/O instructions and can be reset by writing to the parity 
error reset port (U110) . 

Paks 040 and U44 multiplex the 16-bit address coming out of the 
processor onto a 7-bit bus which goes directly to the dynamic RAM 
chips. Pak U76 generates the control signal such that latched 
addresses (LA) 01 thru LA07 (low byte) are shipped off during the 
row address strobe (RAS) portion of the memory cycle. LA08 thru 
LA14 (high byte) are shipped off during the column address strobe 
(CAS) portion of the memory cycle. Refer to any 16K-by-l dynamic 
RAM spec sheet for details of the timing. 

LA00 is not multiplexed into the memory address. It is stripped 
off and stored in U60. During a byte access, it is used to 
determine whether the high or low byte of the word is being 
requested. The low byte is accessed if LA00 is low and the high 
byte is accessed if LA00 is high. During a word access, it is 
insignificant, as it only specifies the difference between the 
high and low bytes of a given word stored in dynamic RAM. 

The processor utilizes positive-true logic on the B'AD bus. Paks 
U45 and U59 are bidirectional drivers to route data in and out of 
the memory chips, which have very little drive capability. Pak 
U60 provides high byte to low byte conversion during DMA. 

The ICP has four sockets for PROM (U88 to U91) , which provide 
from 4K to 16K bytes. The sockets accommodate either 16K or 32K 
EPROMs or ROMs. This choice has no effect on system performance. 

No parity checking is performed on PROM accesses. PROM starts at 
location and goes up to 3FFFH (RAM starts at 4000H) . Paks U88 
thru U91 contain the PROMs, which in production contain the 
following firm/soft ware: 
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U88 Low-byte ICP software 

U89 Low-byte ICP diagnostics 

U90 High-byte ICP software 

U91 High-byte ICP diagnostics 

Paks U66 and U79 are bidirectional drivers wired for 
unidirectional operation. They drive the PROM data out onto the 
processor B'ADxx bus (the PROMs also have very limited drive 
capability) . The ROM/PROM circuit is shown on page 14 of the ICP 
schematics. 

Pak U72 is the PROM configuration selector. To use 4K-by-8 
PROMs, connect ROM (A to B) and ROM 1 (A to C) . To use 2K-by-8 
PROMS, connect ROM (A to C) and ROM 1 (A to B) . See the £/M 
User 's Manual for details about the jumpers. 

Memory on the ICP is divided into three addressable areas: 

flejt Address Description 

0000-3FFF PROM space 

4000-BFFF Dynamic RAM space 

COOO-FFFF Multibus space 
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4. SERIAL PORTS 

The ICP has eight RS232C serial ports implemented with Z80A SI02 

USARTs. The Z8002 selects asyncronous baud rates from 50 to 

38,400 by programming a Zilog Z80A CTC Counter/Timer. Character 
length, parity and number of stop bits are also programmable. See 

the ZllSiQ. 1331 Data Book for details. The RS232C pins supported 
by the ICP are shown below: 



ES212£ sin 

2 Transmit Data 

3 Receive Data 

4 Clear to Send 

5 Request to Send 

6 Data Set Ready 

7 Signal Ground 

8 Data Carrier Detect 
11 Second RTS 

15 Transmit Clock 

17 Receive Clock 

20 Data Terminal Ready 



* CTS is used as the auto transmitter enable. It can connect 
to one of three sources: pin 4, pin 11 or pin 20. To select 
one, see the Plexus 2/21 US&L'S. Manual. 

** Jumper allows Data Carrier Detect to be connected to +12v 
(ON) or to the DCD pin of the modem. 

*** Jumpers allow use of internal or external clock. 

NOTE: The pins for all terminals (and the printer) leave the 
ICP from connectors Jl and J2. These are shown in I/O 
Controller Section 13. 

Each serial port has a DMA channel associated with it. The DMA 

4-1 I/O Controller 



21Q. 21r 


I/O. 


RxD 


I 


TxD 





CTS* 


I 


RTS 





DTR 


O 


Gnd 


- 


+12, DCD** 


I/O 


CTS* 


I 


TxC*** 


I 


RxC*** 


I 


CTS* 


I 
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moves data from local memory to the SIO transmitter. A DMA 
transfer is initiated by the SIO every time its transmitter 
buffer becomes empty while it is in active mode. A rotating 
priority scheme is used so that the most recently serviced SIO 
has lowest priority. 

The DMA function is provided by three AMD9517 DMA chips (U106- 
U108) . These have only an 8-bit data path; to get the contents 
of the appropriate memory location, each DMA chip latches the 
high-order byte of the address into an address latch (U80, U95 
and D96) during the early part of the DMA transfer cycle. It 
then puts out the low-order byte of the address on its own 
address line. See the AM95QQ Peripheral Products Interface Gjiiste 
for operation and timing details on the DMA chips. 

The DMA chip only has one cycle for both retrieving the memory 
data and writing the data to the SIO chip. It uses pak U115 as a 
fake port address generator. When DMA'WRITE is inactive (no DMA 
in progress) , this multiplexor outputs LAOO and LA01 to MLAOO and 
MLA01. This is normal; it allows the Z8002 to address the CTCs, 
SIOs and PIO in the normal manner. However when DMA'WRITE is 
active (a DMA is in progress) the DMA chip takes over the address 
generation of MLAOO and MLA01 and addresses the appropriate SIO 
(or PIO) . 

The CTCs are included in the MLAOO and MLA01 circuit so that they 
cannot be selected accidentally with a . simultaneous memory 
address and IORQ/ from the DMA. Note that ICP DMA only goes from 
local memory out to the SIOs; it writes to the terminals but 
doesn't read from the terminals. This is because there exists an 
order of magnitude more activity going out to the terminals than 
returning. Input from the terminals is limited by number of 
terminals times typing speed. 

The combination of DMA and the sophisticated AMD9517 chips (U106, 
7 and 8) protects the Z8002 from handling too many interrupts. 
The following discussion describes how: 

Assume that output to a 1000-lpm printer is equivalent to one 
terminal's output. Each ICP board must support nine of these. 
If all terminals are set to 19,200 baud (almost 2000 
characters per second) , then the total load to the ICP is 
18000 characters per second, which translates to 18000 
interrupts per second, or a 55-microsecond-per-interrupt 
service time. 

The Z8002 requires 2 microseconds per instruction (clocked at 
4 Mhz) . This allows only 28 instructions to decide which 
character to output and to output it. Even if the Z8002 could 
keep up, it would have time for nothing else (such as 
multiprocessing, screen formatting and special character 
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handling). The addition of DMA on the ICP lowers the number 
of character interrupts by 95%. 

The AMD 9517 DMA chips are wired to provide three DMA channels 
each , so that three of them provide the 9 DMA required channels. 
The INTEL 8237 is a lookalike for this chip. 

The DMA chips are programmed by the processor to transfer one 
byte and then release the buses. This assures that the Z8002 
will get at least every other memory cycle. When an entire block 
of data has been transferred, the DMA generates a vectored 
interrupt to the processor through a CTC. " This informs the 
processor that the DMA is done and the 9517 is ready for another 
task. 

When a character is received by an SIO, a vectored interrupt is 
sent to the ICP processor. 

Paks U102 through U105 are LSI SIO chips. Each chip has two 
channels on board. These are completely separate and only 
coincidentally share the same physical chip. 

Both the processor and the DMA can program the SIO chips with 
terminal characteristics. The SIOs have a byte-wide data path 
and are programmed by a Z8002 OUT instruction to the appropriate 
port. Even though it is a word instruction, only the lower 8 bits 
are used. 
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5. PARALLEL PORT 

The ICP has a single parallel I/O port that is used to connect an 
industry-standard (Centronics-type) line printer. The port is 
based on the Z80A PIO and is also DMA-supported. Control logic 
associated with the port generates all control and handshake 
signals necessary for the DMA to transfer data to a printer 
without intervention from the Z8002. The lines of the parallel 
port are shown below: 



Signal 

p_in 

l 
2 

3 

4 

5 

6 

7 

8 

9 

10 

11 

12 

13 

14 

16 

17 

31 

32 



Return Source PIO 
PJLn I£P_/P_i£ Pin 



19 
20 
21 
22 
23 
24 
25 
26 
27 
28 
29 



30 



ICP 


7 


ICP 


27 


ICP 


28 


ICP 


29 


ICP 


30 


ICP 


31 


ICP 


32 


ICP 


33 


ICP 


34 


Ptr 


6 


Ptr 


14 


Ptr 


13 


Ptr 


12 


ICP 


15 


Ptr 


10 



Signal* 


Mms. 


DATA Strobe/ 


DATA 1 


DATA 2 


DATA 3 


DATA 4 


DATA 5 


DATA 6 


DATA 7 


DATA 8 


Acknowledge/ 


BUSY 


Paper Out (PE) 


Online (SLCT) 


Ground 


Logic Ground 


Chassis Ground 


Input Prime (RESET) 


FAULT 



* All signals are standard TTL levels terminated according to 
the CjanjiXonJLcs. Interface. Specif icat ion. Pin numbers refer to 
Amphenol 57-30360 36 pin connector. 



The port sends a vectored interrupt to the ICP processor 
the printer asserts the FAULT line. 



if 
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6. MULTIBUS ARBITER AND INTERFACE 

The Multibus arbiter on the P/25 uses the parallel arbitration 
technique described in the XEJEE Proposed Microcomp in-Pr System Bus 
Standard (P_7_9JL Bus.) . The arbiter is really distributed; each 
Multibus board is responsible for doing part of the arbitration. 
The common arbitration circuitry resides on the P/25 backplane. 

The ICP uses its block move capability to move data from the 
middle 32K of its memory space (local RAM) to the upper 16K which 
is mapped into system RAM. To do this, it programs a CTC timer 
circuit to request the Multibus every time it reaches a zero 
count (BUS'VSe'ARB'REQ at U99) . When control of the Multibus is 
obtained, the arbiter locks 796'BUSY/ (U84) and interrupts the 
ICP processor (thru the CTC at U98 — signal name 
BUS * ARB • INT • TRG) . The interrupt informs the ICP processor that 
it can begin a transfer to or from main memory. When the 
transfer is complete, the ICP processor resets the arbiter and 
releases the Multibus by setting its multi-micro pin (U34) . 

The ICP Multibus interface is a master which supports only 16-bit 
memory read and write operations. It allows the Z8002 to assert 
one of the eight Multibus interrupt lines (INTO/ - INT7/) . The 
interrupt line is selected by a jumper in a socket at U17. 
However, the value is not optional; it must' be set as specified 
in the £iaxjis r/21 llfi^r's. Hanual. 

The ICP can also be a Multibus slave. This happens when it is 
instructed by the CPU to execute an I/O write. 

The interface initiates a Multibus memory cycle every time the 
ICP processor performs a memory operation in the upper 16K bytes 
of memory (C000H-FFFFH) . Multibus addresses are formed by 
concatenating a six-bit port (U48) with the least-significant 14 
processor address bits (U16, U64, U65) to form a 20-bit Multibus 
address. This port (U48) can be written by the ICP processor 
using standard I/O instructions. 
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7 . INTERRUPTS 

The ICP uses nonmaskable, vectored and nonvectored interrupts. 
The events that cause each type of interrupt are as follows: 

Nonmaskable interrupt — Because there are valid reasons for 
masking most interrupts, the nonmaskable interrupt is only- 
used when a memory parity error or power failure is detected. 

Vectored interrupt — This is the most versatile interrupt, 
used for channel attention, DMA end of process, realtime 
clock, PIO cycle complete, PIO fault, SIO transmit, SIO 
receive, SIO external status and SIO special (break, lost 
carrier, etc.) . 

Nonvectored interrupt — The nonvectored interrupt has only 
one purpose: to inform the Z8002 that its request for the 
Multibus has been accepted. 

7.1. Nonmaskable Interrupts 

Nonmaskable interrupts get their name from the fact that there 
are no instructions that the processor can execute to protect 
itself from them; when they occur, the processor is interrupted 
regardless of other conditions. Because there are valid software 
reasons for disabling most interrupts, the only nonmaskable 
interrupts in the ICP are caused by memory parity errors in the 
local ICP memory and by power failures. 

7.2. Vectored Interrupts 

Vectored interrupts interrupt the processor and then send it a 

vector which identifies the source of the interrupt. The 

interrupt routine depends on the vector, making these the most 
flexible interrupts. 

The ICP uses a serial daisy-chain form of interrupt priority. The 
priority of service depends on location in the daisy chain, which 
is shown in the table below. The daisy chain is implemented with 
the interrupt enable in (IEI) and interrupt enable out (IEO) 
signals, which exist on each CTC, SIO and PIO. 

The sequence of events is as follows: when a particular channel 
of a peripheral chip needs to interrupt the ICP processor, it 
first examines its own priority relative to other onboard 
channels by polling its IEI line. If the IEI is active (high) , 
then no higher priority chip is interrupting and it may proceed. 
If the IEI is not active, then it must wait. 
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Assuming that IEI is active, the chip simultaneously pulls its 
IEO line (active low) inactive and VEC'INT/ (active low) active. 
This interrupts the ICP processor, causing it to issue an 
interrupt-acknowledge cycle. Upon receipt of the interrupt- 
acknowledge, the peripheral chip returns its interrupt vector 
(previously programmed into it) to the ICP processor and 
deactivates VEC'INT/. The peripheral chip then waits for the 
return from interrupt (RETI) signal. (This Z80 standard signal is 
produced by a special port, as described in the I/O Controller 
section 7.4.) . 

Upon receipt of RETI, the interrupt cycle ends. The chip returns 
its IEO to active, enabling other interrupts. 

The following table shows the devices in the daisy chain and 
their priorities: 



Interrupt Pxioxity. Device 



Sources 



HIGH 



LOW 





1 

2 

3 

4 

5 

6 

7 

8 

9 

10 

11 

12 

13 

14 



SIO 

SIO 

SIO 

SIO 

SIO 

SIO 

SIO 

SIO 

CTC 

CTC 

CTC 

CTC 

CTC 

CTC 

PIO 



1 
1 
2 
2 
3 
3 

1 
2 
2 
3 
3 



Chan A Serial Port 

Chan B Serial Port 1 

Chan A Serial Port 2 

Chan B Serial Port 3 

Chan A Serial Port 4 

Chan B Serial Port 5 

Chan A Serial Port 6 

Chan B Serial Port 7 

Chan 3 Channel Attention Port 

Chan 3 Bus Arbiter Interrupt 

Chan 2 DMAO END OF XFER 

Chan 3 DMA1 END OF XFER 

Chan 2 Realtime Clock Ticks 

Chan 3 DMA2 END OF XFER 

Chan A Parallel Port Status 



7.3. Nonvectored Interrupts 

These interrupts can be masked, but they do not return an 
interrupt vector. All nonvectored interrupts jump to the same 
interrupt handler, which takes a poll to find the source of the 
interrupt. The only nonvectored interrupt used by the ICP occurs 
when it receives control of the Multibus. This signal, which 
originates at U98, informs the Z8002 that it can begin a transfer 
to or from main memory. 

7.4. Programming Information 

A translation circuit makes the interrupt acknowledge produced by 
the Z8002 compatible with the Z80 peripheral chips. A similar 



7-2 



I/O Controller 



Plexus Computers Inc P/25 ENGINEERING MANUAL 



translation circuit (see the ICP schematics, page 7) simulates 
the RETI instruction of the Z80 microprocessor. 

When a peripheral chip sends an interrupt, the ICP processor 
issues an interrupt-acknowledge cycle (Ml/ and IORQ/ active 
simultaneously) . The peripheral chip responds with its own 
vector address on the low-order data bus (B'ADxx) . The Z8002 
processes the interrupt and then initializes the RETI (ED4D) 
opcode for which the peripheral chip is waiting, along with a 
special sequence of control lines (Ml/ active and IORQ/ 
inactive) . The peripheral chip sees these control lines and ED, 
followed by 4D on the bus. It interprets this as an interrupt 
reset and releases the interrupt-priority chain. 

Because the Z8002 does not have the RETI opcode that the Z80 
peripheral chips require, this signal is generated by writing to 
a special interrupt-reset port. The port outputs ED at the same 
time Ml goes active and IORQ/ goes inactive; then it outputs 4D. 
To the peripheral chips this circuit it transparent; the signal 
appears to come from the Z8002. 
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8. STATUS AND CONTROL PORTS 

The ICP processor has access to several status and control ports 
using standard word I/O instructions. These are: 

# Sits. £/W Purpose 

4 R Switches for diagnostics and 

initialization 

16 R Switches and jumpers that select channel 

channel attention port I/O address and 
wake-up address 

LEDs for diagnostics 

Enable/disable parity generation and 
checking 

Reset parity error 

Latch holding six most significant 
Multibus address bits 

Channel attention port 

Assert one of eight Multibus interrupt 
lines 

Daisy chain RETI port 

Initialize PIO DMA request 

Parity error vs power fail interrupt 

The addresses of these ports are shown in the I/O Controller, section 9 



4 


W 


1 


w 


1 


w 


6 


w 


8 


R 


1 


W 


- 


w 


1 


w 


1 


R 
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I/O SPACE 



In addition to the status and control ports discussed in the 
previous part, the ICP processor has the following eight-bit LSI 
peripheral chips in its standard I/O space: 



4 
1 
4 
3 



USARTs (2 SIOs each) 
parallel printer port (PIO) 
4-channel counter/timers (CTC) 
4-channel DMA controllers (9517) 



Although these are 8-bit devices, they are referenced only with 
word I/O instructions. This is a peculiarity of the Z8002; its 
ability to do byte-writes to certain ports is limited. The high 
byte is ignored. 

A bus translator converts the Z8000 control bus to the Z80 
control bus so that these peripheral chips can be used. A swap- 
byte buffer allows data transfers from the high bytes of memory. 

A summary of the ICP port addresses and their functions is shown 
below: 



Address # £it£ 



4000 
4001 
4002 
4003 



8 R/W 

8 R/W 

8 R/W 

8 R/W 



R/W £flX_t 

CTC0 - chn 

CTC0 - chn 1 

CTC0 - chn 2 

CTC0 - chn 3 



Function 

Serial Port 
Serial Port 1 
Serial Port 2 



Baud Rate 
Baud Rate 
Baud Rate 



Channel Attn Interrupt 



4010 
4011 
4012 
4013 



8 
8 
8 
8 



R/W 
R/W 
R/W 
R/W 



CTC1 
CTC1 
CTC1 
CTC1 



chn 
chn 1 
chn 2 
chn 3 



Serial Port 3 Baud Rate 
Serial Port 4 Baud Rate 
Serial Port 5 Baud Rate 
Multibus Arbiter Interrupt 



4020 
4021 
4022 
4023 



8 
8 
8 
8 



R/W 
R/W 
R/W 
R/W 



CTC2 
CTC2 
CTC2 
CTC2 



chn 
chn 1 
chn 2 
chn 3 



Multibus Arbiter Request 
Realtime Clock - Level 1 
DMA0 End of Xfer Interrupt 
DMA2 End of Xfer Interrupt 



4030 
4031 
4032 
4033 



8 
8 
8 
8 



R/W 
R/W 
R/W 
R/W 



CTC3 
CTC 3 
CTC 3 
CTC3 



chn 
chn 1 
chn 2 
chn 3 



Serial Port 6 Baud Rate 
Serial Port 7 Baud Rate 
Realtime Clock Interrupt 
DMA2 End of Xfer Interrupt 
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4040 
4041 
4042 
4043 


8 
8 
8 
8 


R/W 
R/W 
R/W 
R/W 


SIO0 
SIO0 
SIO0 
SIO0 


- 


chn 
chn 
chn 
chn 


A 
B 
A 

B 


Data 
Data 
Cntl 
Cntl 


Serial 
Serial 
Serial 
Serial 


Port 
Port 
Port 
Port 




1 

1 


4050 
4051 
4052 
4053 


8 
8 
8 
8 


R/W 
R/W 
R/W 
R/W 


SIOl 
SIOl 
SIOl 
SIOl 


- 


chn 
chn 
chn 
chn 


A 
B 
A 
B 


Data 
Data 
Cntl 
Cntl 


Serial 
Serial 
Serial 
Serial 


Port 
Port 
Port 
Port 


2 
3 
2 

3 


4060 
4061 
4062 
4063 


8 
8 

8 
8 


R/W 
R/W 
R/W 
R/W 


SI02 
SI02 
SI02 
SI02 


- 


chn 
chn 
chn 
chn 


B 
B 
A 
B 


Cntl 
Data 
Cntl 
Cntl 


Serial 
Serial 
Serial 
Serial 


Port 
Port 
Port 
Port 


4 

5 
4 
5 


4070 
4071 
4072 
4073 


8 
8 
8 
8 


R/W 
R/W 
R/W 
R/W 


SI03 
SI03 
SI03 
SI03 


- 


chn 
chn 
chn 
chn 


A 

B 
A 
B 


Data 
Data 
Cntl 
Cntl 


Serial 
Serial 
Serial 
Serial 


Port 
Port 
Port 
Port 


6 
7 
6 
7 


4080 
4090-F 
4190-F 
4290-F 


16 
8 
8 
8 


R 
R/W 
R/W 
R/W 


Switch jumpers 
8237 DMA0 
8237 DMAO 
8237 DMAO 


Wakeup Address 
Internal 
Internal 
Internal 


40A0 


8 


R 


Switch 


Register 


D7 to D4-Diagnosti 

Switches 
D3-Parity Error 



40B0 



40C0 



W 



Outlatch 1 



W Outlatch 2 



D7 to D4-Diagnostic 

LEDs 
D3-Initialize PIO 

DMA Request 
D2-Enable Parity 

(l=Enable) 
Dl-Reset Parity 

(l=Reset) 
DO-Enable Multibus 

Interrupt 

DO to D5-6 MSBs of 
Multibus Address 



40D0 



R Inlatch 1 



Channel Attention 

Port 
D0=Reset 
Dl=Start Command 
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Execution 
D2=Clear Multibus 

Address 
D3 to D7-Unused 



40E0 
40E1 
40E2 
40E3 



R/W 



PIOO 


- chn 


A 


Data 


Printer 


Status 


PIOO 


- chn 


B 


Data 


Printer 


Status 


PIOO 


- chn 


A 


Cntl 


Printer 


Status 


PIOO 


- chn 


B 


Cntl 


Printer 


Status 



40F0 



W 



Daisy Chain Interrupt 
Reset 
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10. CHANNEL ATTENTION PORT 

The channel attention port is at the slave address placed on the 
Multibus by a master to access an ICP. Each ICP has a unique 
address, determined by setting the switches in U68. This binary 
value serves a dual purpose: it is the ICP channel attention port 
address and it is the low-order byte of the wakeup address where 
the ICP seeks its first instructions during initialization. The 
switches represent a binary value between and 255 (8 binary 
bits) . 

CAUTION: The value determined by U68 is NOT a customer 

option. Each ICP must be set according to its slot location 

(ICP 1 or 2) . The proper switch settings are listed in the 
Plexus £/25_ n&ex's Manual. 

A vectored interrupt is sent to the Z8002 whenever a Multibus 
master writes to the channel attention port. The port is 8 bits 
wide and is read by the Z8002 using I/O instructions. The action 
taken depends on the state of the first three bits. If bit is 
high, it causes the ICP to reset itself. If bit 1 is high, the 
ICP performs a standard channel attention; it goes to the channel 
attention address, reads the instructions that the CPU has placed 
there and executes them. If bit 2 is high, the ICP's Multibus 
interrupt line (INTx/) is reset. This is used by the CPU 
processor to clear a Multibus interrupt posted by the ICP. 

The remaining five bits are not used. 

The CPU loads a block of commands into the channel attention 
address before it issues a channel attention to the ICP. 
Typically, the command block contains instruction to move data 
from one location to another (for example - "Move 300 words from 
system RAM to terminal 3 starting at address X and ending at Y") . 

10.1. Reset 

The ICP can be reset by setting bit in the channel attention 
port or by asserting the Multibus INIT/ line on connector PI. 
When the reset is released, the ICP executes its self-test, which 
takes about 15 seconds. 
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11. PSEDDO DMA 

The ICP does not use true DMA to move blocks between local and 
main memory. Instead, it uses a combination of hardware and 
software. 

Data is moved to and from main memory using block move 
instructions executed by the ICP processor. The upper 16K bytes 
of the ICP processor memory address space is mapped into main 
memory. To move data to main memory, the processor executes a 
block move from the middle 32K of memory (its local RAM) to the 
upper 16K. To initiate a transfer, the processor programs a CTC 
channel to provide a pulse every 0.5 microseconds. This pulse 
goes to the Multibus arbiter and causes it to request the 
Multibus. When control of the Multibus is obtained, the arbiter 
sends a vectored interrupt to the processor. The processor then 
initiates a block move of m words (m=~3 2) . When the move is 
complete, the processor signals the arbiter to release the bus by 
resetting its multi-micro bit. 

This technique allows a pseudo DMA task to run in the background 
without monopolizing either the Multibus or local bus. When no 
blocks remain in the DMA queue, the processor disables the CTC 
channel so that no more interrupts are generated. With the 
parameters mentioned above, the pseudo DMA can move 64K 
characters/sec using less than 10% of the processor bandwidth. 
This is fast enough to keep up with 16 terminals running at 19. 2K 
baud plus two line printers at 300 1pm, which is the maximum load 
the P/25 will ever see. 

The number of words in a block move is set in software using the 
LDIR (load direct) instruction. 
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12. PINS, CONNECTORS AND PINODTS 

The electrical level and timing interface for connector PI is 
documented in the l£E£ Proposed Microcomputer £y^£ejn 2ns. standard 
(P796 Standard) . The following exceptions exist to this 
standard: 

Pl-77 Signal name = AACK/ used by the MPU and ICP 

Pl-78 Signal name = PWR'FAIL used by the MPU, ICP et al. 

The ICP does not use connector P2; all the P2 pins on the ICP are 
open. 

Connectors Jl and J2 connect the I/O pins on the ICP to the 
terminal connectors on the back panel. The electrical interface 
for all signals on connector Jl and connector J2 pins J2-1 to 
J2-38 is RS232C compatible at levels of +12 volts and -12 volts. 
Connector J2 pins J2-39 to J2-60 are TTL-compatible and are 
described in the Centronics. Inter fax S pecification . 

12.1. Connector Pinouts 

Connectors Jl and J2 are mounted on the front of the ICP. Ribbon 
cables (86 and 60 pins) connect them to the terminal connectors 
on the back panel. Pinouts for Jl and J2 are as follows: 



Pin # Signal Eame 



£in # 



Jl- 1 


Not Used 


No Connection 


Jl- 2 


Not Used 


No Connection 


Jl- 3 


Not Used 


No Connection 


Jl -4 


Ground 


T3- 7 


Jl- 5 


B'RXCB.SIOl 


T3-17 


Jl- 6 


B'TXCB.SIOl 


T3-15 


Jl- 7 


B'DCDB.SIOl 


T3- 8 


Jl- 8 


B'DTRB.SIOl 


T3- 6 


Jl- 9 


B'RTSB.SIOl 


T3- 5 


Jl-10 


B'CTSB.SIOl 


T3- 4 


Jl-11 


B'CTSB.SIOl 


T3-11 


Jl-12 


B'CTSB.SIOl 


T3-20 


Jl-13 


B'RXDB.SIOl/ 


T3- 2 


Jl-14 


B'TXDB.SIOl/ 


T3- 3 


Jl-15 


Not Used 


No Connection 


Jl-16 


Ground 


T2-7 


Jl-17 


B'RXCA.SIOl 


T2-17 


Jl-18 


B'TXCA.SIOl 


T2-15 


Jl-19 


B'DCDA.SIOl 


T2-8 
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Jl-20 


B'DTRA.SIOl 


T2-6 


Jl-21 


B'RTSA.SIOl 


T2-5 


Jl-22 


B'CTSA.SIOl 


T2-4 


Jl-23 


B'CTSA.SIOl 


T2-11 


Jl-24 


B'CTSA.SIOl 


T2-20 


Jl-25 


B'RXDA.SIOl/ 


T2-2 


Jl-26 


B'TXDA.SIOl/ 


T2-3 


Jl-27 


Not Used 


No Connection 


Jl-28 


Ground 


Tl-7 


Jl-29 


B'RXCB.SIOO 


Tl-17 


Jl-30 


B'TXCB.SIOO 


Tl-15 


Jl-31 


B'DCDB.SIOO 


Tl-8 


Jl-32 


B'DTRB.SIOO 


Tl-6 


Jl-33 


B'RTSB.SIOO 


Tl-5 


Jl-34 


B'CTSB.SIOO 


Tl-4 


Jl-35 


B'CTSB.SIOO 


Tl-11 


Jl-36 


B'CTSB.SIOO 


Tl-20 


Jl-37 


B'RXDB.SIOO 


Tl-2 


Jl-38 


B'TXDB.SIOO/ 


Tl-3 


Jl-39 


B'RXDA.SIOO/ 


TO-17 


Jl-40 


Ground 


TO -7 


Jl-41 


B'TXCA.SIOO 


TO -15 


Jl-42 


B'DTRA.SIOO 


TO -6 


Jl-43 


B'DCDA.SIOO 


TO -8 


Jl-44 


B'RTSA.SIOO 


TO -5 


Jl-45 


B'CTSA.SIOO 


TO -4 


Jl-46 


B'CTSA.SIOO 


TO-11 


Jl-47 


B'CTSA.SIOO 


TO-20 


Jl-48 


B'RXDA.SIOO/ 


TO-2 


Jl-49 


B'TXDA.SIOO/ 


TO -3 


Jl-50 


Ground 


T4-7 


Jl-51 


B'RXCA.SI02 


T4-17 


Jl-52 


B'TXCA.SI02 


T4-15 


Jl-53 


B'DCDA.SI02 


T4-8 


Jl-54 


B'DTRA.SI02 


T4-6 


Jl-55 


B'RTSA.SI02 


T4-5 


Jl-56 


B'CTSA.SI02 


T4-4 


Jl-57 


B'CTSA.SI02 


T4-11 


Jl-58 


B'CTSA.SI02 


T4-20 


Jl-59 


B'RXDA.SI02/ 


T4-2 


Jl-60 


B'TXDA.SI02/ 


T4-3 


J2-1 


Not Used 


No Connection 


J2-2 


Not Used 


No Connection 


J2-3 


Not Used 


No Connection 


J2-4 


Ground 


T7-7 


J2-5 


B'RXCB.SI03 


T7-17 


J2-6 


B'TXCB.SI03 


T7-15 


J2-7 


B'DCDB.SI03 


T7-8 


J2-8 


B'DTRB.SI03 


T7-6 


J2-9 


B'RTSB.SI03 


T7-5 
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J2-10 


B'CTSB.SI03 


T7-4 


J2-11 


B'CTSB.SI03 


T7-11 


J2-12 


B'CTSB.SI03 


T7-20 


J2-13 


B'RXDB.SI03/ 


T7-2 


J2-14 


B'TXDB.SI03/ 


T7-3 


J2-15 


Not Used 


No Connection 


J2-16 


Ground 


T6-7 


J2-17 


B'RXCA.SI03 


T6-17 


J2-18 


B'TXCA.SI03 


T6-15 


J2-19 


B*DCDA.SI03 


T6-8 


J2-20 


B*DTRA.SI03 


T6-6 


J2-21 


B»RTSA.SI03 


T6-5 


J2-22 


B'CTSA.SI03 


T6-4 


J2-23 


B'CTSA.SI03 


T6-11 


J2-24 


B'CTSA.SI03 


T6-20 


J2-25 


B'RXDA.SI03/ 


T6-2 


J2-26 


B'TXDA.SI03/ 


T6-3 


J2-27 


Not Used 


No Connection 


J2-28 


Ground 


T5-7 


J2-29 


B'RXCB.SI02 


T5-17 


J2-30 


B'TXCB.SI02 


T5-15 


J2-31 


B'DCDB.SI02 


T5-8 


J2-32 


B'DTRB.SI02 


T5-6 


J2-33 


B'RTSB.SI02 


T5-5 


J2-34 


B'CTSB.SI02 


T5-4 


J2-35 


B'CTSB.SI02 


T5-11 


J2-36 


B'CTSB.SI02 


T5-20 


J2-37 


B'RXDB.SI02/ 


T5-2 


J2-38 


B'TXDB.SI02/ 


T5-3 


J2-39 


PDAT7 


PAR- 9 


J2-40 


PDAT6 


PAR- 8 


J2-41 


PDAT5 


PAR-7 


J2-42 


PDAT4 


PAR- 6 


J2-43 


PDAT3 


PAR--5 


J2-44 


PDAT2 


PAR- 4 


J2-45 


PDAT1 


PAR- 3 


J2-46 


PDATO 


PAR- 2 


J2-47 


PBRDY/ 


PAR-1 


J2-48 


PBSTB/ 


PAR-10 


J2-49 


POSCXT 


PAR-1 5 


J2-50 


PFAULT/ 


PAR-32 


J2-51 


PSLCT 


PAR-1 3 


J2-52 


PPE 


PAR-1 2 


J2-53 


PBUSY 


PAR-1 1 


J2-54 


PINPPRM 


PAR- 31 


J2-55 


Ground 


PAR-1 4 


J2-56 


Ground 


PAR-1 6 


J2-57 


Ground 


PAR-1 9 


J2-58 


Ground 


PAR- 20 


J2-59 


Ground 


PAR-21 


J2-60 


Ground 


PAR-22-30 
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13. DMA OPERATION 

Refer to the ICP schematics, the block diagram and a copy of the 
AMD9517 specifications as necessary for this discussion. 

The ICP uses true DMA to transfer data from local memory to the 
SIOs and PIO. 

The DMA chips are programmed similarly to the SIOs, CTCs and PIO. 
They have a few different registers, but they use similar I/O 
commands and the hardware is identical. However, the actual 
process of transferring data from local memory to the SIOs and 
PIO is unlike anything on the board. It proceeds as follows: 

(a) The ICP processor programs the DMA chip with a transfer 
type, a word count and a starting address. 

(b) The DMA waits until one of the SIOs (or PIOs; they work 
similarly) sends it a RDYX.SIOY/ signal which informs the DMA 
that the transmitter buffer on the SIO is empty. This is the 
normal case for an SIO when it is not performing work and is 
the case every time it moves a character from the internal 
transmit buffer, where the DMA puts the character, to the 
shift register where the character is actually output onto the 
RS232C transmit line. 

(c) When this READY signal originates at the SIO, it causes 
the DMA to fetch another character from local memory. The DMA 
activates its RQ line (which is passed through the DMA at 
U106) , which goes to the BUSREQ/ input of the Z8002 and 
demands control of all the ICP buses. The Z8002 yields 
control of the buses to the DMA at the end of its current 
machine cycle, by tristating everything and activating 
BUSACK/. 

(d) The DMA outputs its AEN signal to activate its high-order 
address latch. The DMA only has 8 address lines and it needs 
to provide a 16-bit address to memory, so it puts the high- 
order address bits on its data bus and latches them into the 
accessory address latches by activating its ADSTB signal. 

(e) Besides latching the high-order address bits into the 
accessory latch, the ADSTB signal serves as the normal 
processor address strobe; it starts off the memory cycle along 
with the normal RAS and CAS signals. It is then used by pak 
U142 to generate a DMA'RDY signal that slows the DMA down to 
match the memory speed. After the prerequisite amount of time 
(about 500 microseconds after ADSTB goes active) , the DMA 
generates its DACK signal to tell the SIO chip that there is a 
valid character on the B'ADxx bus. 
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(f) The DMA forces the ICP processor to tristate (give up 
control of) the bus by activating BUSREQ/. It then takes 
over, performing all activities necessary to write the 
character into the SIO chip. It releases its AEN and HRQ 
signals and waits for the SIO to request another character. 
During the time the DMA chip has control of the buses, the 
memory and peripheral chips function as they would if the ICP 
processor were in control. 
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14. ICP SOFTWARE CONCEPTS 

This section provides an overview of the functions performed on 
the ICP board and the order in which they must be performed. 
This section is not intended to be exhaustive or complete. For 
details of the ICP software, see the Plexus software 
documentation. 

The main strengths of the ICP are as follows: 

(a) It is intelligent — it has a Z8002 16-bit microprocessor 
on board. 

(b) It has 32K bytes of DRAM memory on board, all for 
software use. 

(c) It has pseudo-DMA access to the system memory without 
intervention of the CPU. 

(d) It has true DMA from ICP local memory out to the nine 
ports. 

To make use of these strengths, the ICP works in the following 
way: The Z8002 and the 32K bytes of DRAM allow the ICP to locally 
buffer large quantities of data (a screenful for each of eight 
CRTs) , handle the character interrupts coming back from each 
terminal and notify the CPU only when an entire screenful of 
information is completed for a terminal. 

NOTE: If it were necessary to put out a full CRT screen every 
time, this arrangement could cut the character-interrupt 
handling time by a factor of 1920. Because most information 
is output in smaller than screenful blocks, this arrangement 
typically cuts CPU interrupts by a factor of 20. 

This basic idea is implemented in several steps. First, the CPU 
builds a command block in system memory at the ICPs channel 
attention address. This may take approximately 100 memory 
accesses, but does not occupy the Multibus. Then the CPU 
interrupts the ICP with an single I/O write over the Multibus. 
This interrupt is called a channel attention. It causes the ICP 
to go to the channel attention address and read the instructions 
there. This takes only 1 or 2 Multibus accesses of 64 bytes 
each. 

NOTE: Pseudo DMA transfers across the Multibus are limited to 
64 bytes, allowing the ICP to hold the Multibus for a maximum 
of 100 microseconds. 

The ICP then interprets and executes the command block. For 
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example, the command block may order the ICP to write a block of 
characters from memory to terminal 5. Assuming it is interpreted 
correctly, the ICP acknowledges the CPU by posting a command 
accepted status in system memory and interrupting (796 'INT/) the 
CPU. 

The ICP again uses the Multibus to access system memory. It 
retrieves the data from memory (the command block contains 
pointers) and transfers it to ICP local memory. Then the ICP 
begins to output the characters. Finally, after outputting all 
the characters, the ICP accesses the Multibus, transfers a 
command complete status into system memory and interrupts the CPU 
to tell it that the new status (command complete) is there. 

This arrangement works both ways: the CPU can also order the ICP 
to write characters from a terminal to system memory. In this 
case, the ICP loads its local memory with characters from the 
terminal and transfers them to system memory over the Multibus. 

NOTE: The entire block of characters has been output with 

only two interrupts to the CPU instead of the multiple 

interrupts which would have been required if the CPU had 
handled the transfer directly. 

14.1. Timing Considerations 

At 9600 baud, a Snaracter transfer from local memory to the 
terminal takes ll - m i cr osecond, most of which is spent printing the 
character at the terminal. This would require that the Z8002 
process 1000 character interrupts per second to keep up with one 
terminal printing at full speed. Actually the Z8002 can process 
interrupts (including typical handling) at the rate of about 2000 
per second. Without help f the Z8002 could not support 8 terminals 
running at full speed. 

The Z8002 is assisted by the AMD9517 chips, which do for the 
Z8002 what the ICP does for the CPU: handle the interrupt 
received from each character output without interrupting the 
Z8002 until the entire message has been completed. There are 
nine DMA channels, one for each terminal. Instead of handling 
all the interrupts for each character, the Z8002 need only handle 
1 to 5% • as many interrupts, depending upon the number of 
characters per message. 

14.2. Bus Arbitration 

The ICP competes for the bus through a parallel priority encode 
(as opposed to a daisy chain) . While the hardware places no 
restrictions on the duration of Multibus accesses, software 
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limits each access to 100 microseconds. 

The ICP uses pseudo-DMA to transfer data from its local memory to 
and from system memory, using the block move capability of the 
Z8002. While not true DMA (the Z8002 gets involved) , it is better 
than conventional memory-to-memory moving because it does not 
require a software loop, and it requires only one instruction 
execution by the Z8002. Presently, it takes 13 Z8002 cycles to 
transfer one word, which gives an aggregate transfer rate of 
308K-words per second. This translates to 30.8 words 
(approximatly 64 bytes) per 100 microseconds. 

To keep all terminals running at full speed requires data 
transfers across the Multibus to the ICP 1000 times a second. To 
accomplish this, the ICP must send data, then release the bus 
every millisecond. Because the P/25 is arranged so that no 
controller occupies the Multibus more than 10% of the time, this 
allows 100 microseconds per transfer, which limits transfers to 
64 bytes. This is arranged in P/25 software. 

To accomplish a transfer, the ICP must: 

(a) Program CTC2 (U99) channel to request the bus. 

(b) Do an MRES instruction to activate the MO/ line, which 
enables the bus request onto the physical bus. 

(c) When the bus is granted, send a nonvectored interrupt to 
the Z8002. The interrupt handler should respond by 
transferring the data (maximum of 64 bytes). 

(d) When the data has been transferred, issue an MSET 
instruction to clear the bus request. 

This sequence of steps should be repeated, if necessary, for each 
64-byte block, until the message has been completely transferred. 
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1 . INTRODUCTION 

The P/25 memory system contains 16K bytes of EPROM, 2K bytes of 

static RAM and from 512K bytes to 2M bytes of dynamic RAM. The 

EPROM and static RAM are located on the processor board, and the 
dynamic RAM is on separate memory boards. 

All system memory, including EPROM, static RAM and dynamic RAM, 
features a dual-port memory access arrangement. All memory can 
be accessed by the onboard Z8001A or by another bus master via 
the Multibus interface. 

The dynamic RAM includes an error detection and correction (EDO 
feature and a refresh circuit, both located on the processor 
board. 

Physical address locations for EPROM, static RAM and dynamic RAM 
are shown below: 

EPROM Segment 0, Offset 0000 to 7FFEH 

Static RAM Segment 0, Offset 8000 to 87FEH 
Dynamic RAM Segments 4 to 126, Offset 0000 to FFFEH 



1-1 Memory 



Plexus Computers Ihc p/25 ENGINEERING MANUAL 



2. PRINCIPLES OP OPERATION 



2.1. Physical and Logical Memory Space 

The principle of physical and logical address space is essential 
to the P/25. While the dynamic RAM memory exists in a physical 
address spacer it is never accessed by its physical address. To 
the rest of the P/25, data resides in a logical address space. 
The page map RAM (Figure 1, block 8), under control of the 
operating system, remembers the relationship between logical and 
physical memory. It acts like a file clerk, converting logical 
to physical addresses. 

Each physical memory address is defined by 23 bits. This is 
shown in the Processor section, Figure 3. The 11 low-order bits 
are the offset, which pass through the page map RAM unchanged. 
The 12 high-order bits are manipulated by the page map RAM which 
uses them to select one of 3 2 map sets and one of up to 3 2 2K 
pages in the map set. The 11 low-order bits define the address 
within the 2K page. 

For a detailed description of this process, see Processor section 
2.1.1. 

2.2. Dual-Port Memory 

The dual-port memory system in the P/25 reduces the memory access 

overhead of the Z8001A, which shares common memory access with 

other Multibus masters. This dual-port arrangement allows the 

Z8001A and another Multibus master to access memory at the same 

time. The memory access cycles are interleaved and memory 

arbitration, performed by the local bus arbiter, is done on a 
single-word or byte basis. 

2.3. Error Detection and Correction 

The P/25 memory system includes error detection and correction 
(EDO circuits, implemented with the AMD 2960 chip. These 
circuits, shown in Figure 1 as block 16, correct single-bit 
errors and detect double-bit errors. 

The EDC generates checkbits based on a modified hamming code. For 
a 16-bit word, six checkbits are required. In a word-write 
operation, six checkbits are generated by the EDC and stored in 
the memory. These checkbits are read along with 16 data bits in a 
word-read operation. It then generates a new set of checkbits to 
compare with the checkbits read in. If a single-bit error is 
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detected, the EDC corrects it and flags the ERROR line. If a 
double-bit error is detected, both the ERROR and MULTI-ERROR 
lines are activated. If no errors are detected, the EDC is 
transparent to the device accessing memory. 

EDC errors cause the error status latches to save the address of 
the memory location that caused the error, the six-bit syndrome 
code generated by the EDC and several status bits describing the 
memory access. These are the same latches that store information 
about memory page attribute errors. The information format is 
shown in the Processor section, Figure 11. 

When an EDC error occurs, the MMU goes into an error condition. 
Subsequent errors do not update the error status latches until 
the error condition is cleared by the processor, which performs a 
special write to port FFAO (this address is one of the status 
latches) . 

The EDC is controlled by the processor through a special port at 
address FF80. It is used in internal control mode, and must be 
initialized before checking can be enabled. After 
initialization, checking is enabled by writing a logical one to 
bit A3 of the control port (FF80) . 

2.4. Circuit and Timing Analysis 

This section analyzes the read/write operations for different 
types of memory cycles. These are: 

(1) EPROM/static RAM read cycle 

(2) Static RAM write cycle 

(3) Dynamic RAM read cycle 

(4) Dynamic RAM write cycle 

(5) Dynamic RAM BYTE write cycle 

Timing diagrams for the above memory cycles are shown in Figures 
2 through 6. 

2.4.1. Z8001A EPROM or Static RAM Read Cycle 

The EPROM/static RAM read cycle is four clock cycles long. One 
wait-state is inserted to match the three-clock-cycle Z8001A 
running speed with the slow access time of EPROM and static RAM. 
The timing diagram is shown in Figure 2. 



2-2 Memory 



Plexus Computers Inc p/25 ENGINEERING MANUAL 



The read cycle begins in Tl when the address strobe (AS/) signal 
is asserted and the address is output. If the Multibus and 
refresh circuitry do not contend for local address and data 
buses, then ZGRANT/ and MEMRQ/ are pulled low sequentially, 
starting at the falling edge of clock cycle Tl. MEMRQ/ is the 
signal to notify the timing sequencer (block 22) to start the 
timing program for a read cycle. 

After receiving MEMRQ/, the timing sequencer synchronizes 
generation of the mapped physical address by asserting a PMREQ 
signal (active HIGH) , which notifies the memory system that a 
physical address on connector P2 is valid. The memory address 
decoder (block 39) decodes the higher eight address lines to 
generate either an EPROM CS/ signal (see the processor 
schematics, page 4, U112 pins 6 and 8) or a static RAM CS/ signal 
(see the processor schematics, page 4, U109 pin 10) . EPROM 
occupies the lower address space in segment 0. Static RAM 
occupies the upper space. 

The WAIT/ line (block 40) is controlled by the wait-state 
generator. It is pulled low after the DRAM-EPROM/ signal (see the 
processor schematics, page 4, U3 , pin 8) is activated. WAIT/ 
stays low for one clock cycle and is pulled back to high by the 
OESC/ line (block 22) which is controlled by the timing 
sequencer. 

A memory cycle is then initiated. Maximum allowable access time 
for the parts used in the P/25 system is 450 nsec. The data read 
from EPROM/static RAM flows through data buffers (block 21) to 
the local memory/data bus and through another data buffer (block 
5) to finally settle on the the Z8001A MA/D bus at the beginning 
of T3. This satisfies the 20-nsec minimum setup time before the 
falling edge of T3. 

The timing sequencer is also responsible for generating a signal 
to indicate the end of a memory cycle. This signal, which is 
called CYCEND/, is a 66-nsec active-low pulse. The local bus 
arbiter repositions itself and starts arbitration for the next 
memory cycle. 

2.4.2. Z8001A Static RAM Write Cycle 

Figure 3 shows the timing for the Z8001A static RAM write cycle. 
Except for those pertaining to a write cycle, the circuit 
operations and timing analysis are the same as in the previous 
read cycle. 

The most important timing consideration in a write cycle is the 
data setup time and data hold time. The 2114 static RAM (see the 
processor schematics — U43 through U46) requires a minimum of 
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135-nsec data-setup time and 0-nsec data hold time. Both 
requirements are met as described in the next paragraph. 

The write-enable (WE/) strobe is pulled low before the falling 
edge of T2 and pulled back to high after the falling edge of T3 . 
Because a WAIT cycle is inserted, a minimum of 500-nsec active- 
low WE/ pulse is generated. This satisfies the minimum of 135- 
nsec WE/ pulse requirement. The valid data settles on the data 
inputs of the 2114 at the falling edge of T2. This guarantees a 
500-nsec data setup time. The data is not removed before the WE/ 
signal is pulled to HIGH, so the 0-nsec data hold time is 
satisfied. 



2.4.3. Dynamic RAH Read Cycle 

The Z8001A runs at a frequency of 5 Mhz, which implies a 600-nsec 
memory cycle when no wait-state is inserted. 

NOTE: This time accounts for memory mapping (necessary in a 
multi-user, multi-tasking environment) and error detection and 
correction. 

The timing diagram for a read cycle is shown in Figure 4. The 
figure also shows the relative timing relationships between when 
the Z8001A initiates the cycle and when the Multibus initiates 
the cycle. 

A read cycle begins with the assertion of PMREQ (active HIGH) . 
The memory board with switch settings that match the highest five 
address lines on connector P2 is selected and a BRDSEL signal is 
generated. The corresponding row address strobe (RAS/) of the 
bank selected by the next three address lines is also activated, 
which latches in the row address. The row address consists of the 
lowest seven address lines, which are selected by the 
multiplexor. 

The column address strobe (CAS/) and the signal which selects the 
column address are controlled by a delay line. 

NOTE: Since the CAS/ and the column addresses are generated 
from two different paths, it is important to note that the 
skew problem does not exist in these two paths. This is shown 
in the following worst-case timing calculation: 

Generation of MUX (Delay Line) max 50 nsec 

Multiplexors select COLUMN address max 15 nsec 
(propagation delay from SEL 
input to data output) 
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Column address buffers (74S240) max 9 nsec 

max 74 nsec 

Generation of CAS/ (delay line) min 75 nsec 
CAS/ buffers (74S241) min 3 nsec 



min 78 nsec 



The above calculations show a 4-nsec minimum setup time for the 
column address before activation of the CAS/ signal. 

After activation of CAS/, a maximum of 135 nsec is required to 
place the data on the output pins of the 64K memory chips. 

2.4.3.1. EDC Timing 

Latch Enable In (LEIN) controls latching of the input data. When 
LEIN is low, the data input latch and checkbit input latch are 
latched to their previous state. The LEIN (see the processor 
schematics, page 13) is pulled low when the 16-bit data and six 
checkbits read from the memory are stabilized. The EDC chip then 
generates six checkbits for the 16-bit data in the input latch 
and compares them with the six checkbits in the checkbits input 
latch. If one or more errors are detected, ERROR/ goes low. If 
two or more errors are detected, MUL-ERROR/ goes low. The data 
(corrected if a single-bit error is detected) is latched into the 
EDC output latch when LEOUT signal is pulled low. 

NOTE: The output latches are enabled by OEO/ and OE1/ before 
LEOUT is pulled low. 

If the Z8001A initiates the memory cycle, then the data is 
latched into the Z8001A buffers at the falling edge of clock 
cycle T3. If the cycle is initiated by the Multibus, then data is 
latched into U31 and U52 when CYCEND/ is asserted. In either 
case, the end of a memory cycle is signaled by the assertion of 
the CYCEND/ signal controlled by the timing sequencer. 
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2.4.4. Dynamic RAM Write Cycle 

The timing diagram for the dynamic RAM write cycle is shown in 
Figure 5. The BRDSEL, RAS/, CAS/, ROW address and COLUMN address 
are generated in the same way as in the read cycle. 

In a write cycle, the EDC chip is operated in the GENERATE mode. 
In this mode, six checkbits are generated to match the 16-bit 
data on the local data bus. The checkbits are present at the 
outputs of CBO to CB5. The output latch in the EDC chip is 
disabled in a write cycle. Timing for the 16-bit data and six 
checkbits available in the RAM is calculated as follows: 

Data available on the local bus max 87 nsec 
(data from Multibus available sooner) 

Checkbits generation max 32 nsec 

Data buffer delay (block 32, 74S240) max 7 nsec 

Data buffer delay (memory board) max 7 nsec 



max 133 nsec 



The above timing is referenced to the rising edge of clock cycle 
T2. The WE/ strobe in a dynamic RAM write cycle is generated 
approximately 180 nsec after the rising edge of T2. It stays low 
for about 130 nsec (mininum WE/ low requirement is 55 nsec) . The 
later activation of WE/ ensures meeting the 0-nsec data setup 
time requirement for 64K dynamic RAMs. 

Like the read cycle, the timing sequencer generates the CYCEND/ 
to end a memory cycle. 

2.4.5. Dynamic RAN Byte-Write Cycle 

The dynamic RAM byte-write operation requires special attention. 
It actually consists of a word-read and a word-write operation. 
When the byte-write operation is performed, a wait-state is 
inserted. 

The word-read is performed because the six checkbits are 
generated for the corresponding 16-bit data. When a low byte or a 
high byte is going to be changed, the entire word with six 
checkbits must be read from memory. In the read cycle, the new 
byte (along with the byte which is not to be changed) are latched 
into the input latch in the EDC chip. A word-write operation is 
then performed. The EDC chip generates a new set of six checkbits 
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for the new 16-bit data. 

Figure 6 shows the timing diagram for the byte-write operation. 
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1. MULTIBUS BACKPLANE AND INTERFACE 

Most circuitry in the P/25 is located on cards that plug into a 
Multibus backplane. The backplane has 6 slots. It contains a 
processor board, one or two memory boards, one or two ICPs and an 
IMSC disk and tape controller. The processor and memory boards, 
which use connector P2, must be installed in slots 1 through 3. 

A typical system may be configured as follows: 

£l££ Contains 

1 First Memory Board 

2 Second Memory Board (Optional) 

3 Processor 

4 First ICP 

5 Second ICP (Optional) 

6 IMSC Disk and Tape Controller 

Connector PI contains the standard Multibus signals and power 
connectors. All connections to the system memory array are on 
connector P2. 

The backplane also contains a bus priority arbitrator and a clock 
generator. The priority resolver arbitrates Multibus requests 
from bus masters using the parallel resolving method. It allows 
up to four bus masters on the backplane. The clock generator is 
an oscillator and driver that generates the 10-Mhz bus clock 
(BCLK/) used by all bus masters to synchronize their arbiters. 

1.1. Multibus Interface 

This section describes the Multibus interface used in the Plexus 
P/25 computer. Use the I££E Proposed Mic rocomputer System Bus 
Standard (P796 Bjis.) in conjunction with this section for a 
complete description of the P/25 Multibus. 

The standard modules which are connected to the Multibus in the 
P/25 are: a) the processor board, b) disk and tape controller, c) 
one or two serial I/O controllers and d) one or two memory array 
boards. Other user-optional Multibus I/O controllers may be 
added. The general Multibus interface is discussed below. Any 
restrictions specific to each module are noted. 

1.1.1. Multibus Elements 

(Refer to the P796 Standard, sections 2.1.1 - 2.1.2.) 

In the P/25, the CPU acts as a bus master, the disk and tape 
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controller and the ICP act as both bus masters and slaves, and 
the MMU acts as a bus slave. Other I/O controllers act as either 
bus masters and/or slaves. 

NOTE: The MMU is physically located on the CPU (processor) 
board. 



1.1.2. Multibus Signal Classes 

(Refer to the P796 Standard , section 2.1.3 and section 3) 

Most of the Multibus signal lines used by the P/25 are used as 
defined in the P796 Standard , section 2.1.3, and have the timing 
and electrical characteristics as defined in the P796 Standard f 
section 3. 

1.1.2.1. Connector PI 

The following table shows and describes the connector PI Multibus 
signals. Those which are not identical to the pins in the P796 
Standard are noted. 



Control Lines 



Signal name. 
Bus Clock 
Mem Write Cmd 
Mem Read Cmd 
I/O Write Cmd 

I/O Read Cmd 

2 

Transfer Ack Line 

Initialize 
Advanced Ack Line 



Symbol 


Sianal Generated by 


BCLK/ 


MB Backplane 


MWTC/ 


Current Bus Master 


MRDC/ 


Current Bus Master 


IOWC/ 


Current Bus Master 


IORC/ 


Current Bus Master 


XACK/ 


Current Bus Slave 


INIT/ 


Power Supply 
Reset Button 
CPU 



AACK/ 



MMU 



Signal Used b_y_ 

Any MB Module 

MB Memory Slave 

MB Memory Slave 

Current MB Slave 

Current MB Slave 

Current Bus Master 

Any MB Module 
Any MB Module 
Any MB Module 

Current Bus Master 
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Address and Inhibit Lines 



Signal name 
Address Lines 

Inhibit 1 Line 2 
Inhibit 2 Line 2 
Byte High Enable 



£ymbfll Signal Genera ted by Signal Used by 

ADR07- Current Bus Master Any MB Slaves 
ADR13/ 

INH1/ Not Used 

INH2/ Not Used 

BHEN/ Current Bus Master Bus Memory Slave 



Constant Clock 



CCLK/ Not Used 



Data Lines 



Signal uama 
Data Lines 



Symbol Signal Generated, jay. Sisnal used by. 



DATO/- if write: 

DATF/ Current Bus Master 

if read: 

Current Bus Slave 



Current Bus Slave 
Current Bus Master 



Multibus memory commands are not supported for the CPU bus 
master. 
2 

XACK/ does not meet the P796 Standard requirement for INH1/ 
and INH2/ signal timing since these signals are not used by the 

If a timeout occurs, XACK/ must be generated by the Current 
Bus Master. 
4 

Not a P_Z2£ Standard standard signal. Electrical characteris- 
tics same as XACK/. 
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Interrupt Lines 



Signal Mme. 

c 

Interrupt Requests" 



Interrupt Ack" 



Symbol Signal Generated hx Signal ns^d. ny. 

INTO/- Any Bus Module CPU Master 
INT7/ 

INTA/ Not Used 



Bus Exchange Lines 



Signal Nam e 
Bus Request 
Bus Priority IN 

Bus Priority OUT 6 
Bus Busy 

Common Bus Request 



BREQ/ 


Any Bus Master 


MB Backplane 


BPRN/ 


MB Backplane 


Highest Requesting 
Bus Master 


BPRO/ 


Not Used 




BUSY/ 
CBRQ/ 


Current Bus Master 
Not Used 


Any Non-Current 
Bus Master 



Only non-bus-vectored interrupts are supported, 
the P796 standard, section 2.3). 

Daisy-chain priority schemes are not supported. 



(Refer to 
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Power Pail/Restart Lines 



signal iiame 

AC Low 

Memory Protect 

Power Pail Int 7 

Power Fail Sense 

Power Fail Sense 
Reset 



Symbol signal Generate £y_ sj.c[nai iiaed Jay 

ACLO/ Not Used 

MPRO/ Not Used 

PFIN/ Power Supply Any MB Module 

PFSN/ Not Used 

PFSR/ Not Used 



This signal appears on a nonstandard pin (Pl f pin 78). 
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1.1.2.2. Connector P2 

Connector P2 connects the processor board to system memory. 
These pins are unique to the P/25; they are not Multibus 
standard. Pinouts for connector P2 are as follows: 

NOTE: The letter P in front of a signal name indicates that 
it goes to connector P2. For example, DATO on Pi is similar 
to PDATO on P2. 



1 


PADR10 


2 


PADRF 


3 


PADRE 


4 


PADR7 


5 


PADRD 


6 


PADR5 


7 


PADRC 


8 


PADR6 


9 


PADRB 


10 


PADR4 


11 


PADRA 


12 


PADR3 


13 


PADR9 


14 


PADRO 


15 


PADR8 


16 


PADR1 


17 


Ground 


18 


PADR2 


19 


PADR11 


20 


Ground 


21 


PADR12 


22 


Ground 


23 


PMREQ 


24 


PMREQ 


25 


PADR15 


26 


PADR14 


27 


RFSH 


28 


RFSH 


29 


Ground 


30 


PADR13 



31 


Ground 


32 


Ground 


33 


not used 


34 


not used 


35 


PREAD 


36 


WEL/ 


37 


PWRITE 


38 


WEH/ 


39 


PDAT/ 


40 


PDATO 


41 


PDAT3 


42 


PDAT2 


43 


PDAT5 


44 


PDAT5 


45 


PDAT7 


46 


PDAT6 


47 


PDAT11 


48 


PDAT10 


49 


PDAT2 


50 


PDAT8 


51 


PDATA 


52 


PDAT9 


53 


PDATC 


54 


PDATB 


55 


PDATE 


56 


PDATD 


57 


PDAT13 


58 


PDATF 


59 


PDAT15 


60 


PDAT14 



1.1.3. Data Transfer Operations 

(Refer to the P796 standard, section 2.2) 

P/25 data transfer operations work as described in the £7_9JL 
Standard, section 2.2. The exception is that the inhibit 
operations (INHl/ and INH2/ — PJ.96. Standard, section 2.2.2.7) 
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are not implemented. 

1.1.4. Interrupt Operations 

(Refer to the P796 Standard, section 2.3) 
Only non-bus-vectored interrupts are supported. 

1.1.5. Multibus Exchange 

(Refer to the £195. Standard, section 2.4) 

The P/25 bus exchange scheme is a subset of the parallel 
arbitration technique described in the P796 standard, section 
2.4.2.2. 

Once a master has been granted control of the bus (BPRN/) , it 
maintains control by holding the busy line (BUSY/) active. Each 
bus master is only allowed to control the Multibus for 100 
microseconds; after this, it must relinquish the bus by 
deactivating BUSY/. This time period allows transfers of 64 
bytes maximum. 

NOTE: The IMSC may be allowed to hold the Multibus longer if 
this can be implemented without degrading system performance. 

Bus Priority Out (BPRO/) and Common Bus Request (CBRQ/) are not 
used by the P/25 but may be used by user-supplied I/O 
controllers. 

More detailed information about the P/25 Multibus is contained in 
the IEEE Proposed Microcomputer Syatam fiiia Standard (P796 Bus.) 
which is provided in this section of this manual. 
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1. IMSC OVERVIEW 

The intelligent mass storage controller (IMSC) is a double-height 
Multibus card that controls interaction between the P/25 CPU and 
MMU and the disk and tape drives. 

The IMSC communicates with the CPU and MMU via the Multibus. The 
CPU provides instructions in the form of command and status 
blocks, and the MMU is used to access memory. Disk storage is 
accessed over an industry-standard storage module disk (SMD) 
interface, and the tape drive is accessed via eight data lines 
and eight control lines. 

The IMSC is equipped with a Zilog Z8001 microprocessor, 128K 
bytes of local memory and DMA. It normally controls one disk 
drive and one tape drive (P/25 standard configuration) ; however 
it is capable of controlling three additional disk drives. 

The CPU controls the IMSC in almost the same way as it controls 
the ICPs. It builds a command block in the IMSC's wakeup address 
space, then interrupts the IMSC Z8001 with a channel attention. 
The IMSC receives and acknowledges the channel attention, then 
reads the command block, which contains its instructions. 

The 128K bytes of local RAM is organized as five I/O data 
buffers, each capable of storing an entire disk track. These 
eliminate the slowdowns caused when two or more processes need 
constant access to disk. Instead of reading information from the 
disk one block at a time, the IMSC can read an entire track and 
store it in the buffers. When the process is ready for the next 
block, the buffer provides it. The process appears to have the 
entire disk to itself. 

The P/25 uses an Archive Intelligent Tape Drive, which performs 
many of the functions normally handled by the controller. This 
simplifies the IMSC's dealings with the tape drive. 

The functional blocks of the IMSC board are shown in Figure 1. 

1.1. References 

For a complete description of the disk drive operation, see the 
Plexus Winchester D_isJi Manual for the required disk size. For a 
description of the tape drive operation, see the Plexus 
Tape D_Li:££ Manual. 
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2. PROCESSOR 

The IMSC is equipped with a Zilog Z8001 microprocessor which runs 
at 4 Mhz. The Z8001 runs in system and normal mode, and uses 
only standard I/O space (special I/O space isnot used) . It is 
described in the Zilog Z800Q CPU Technical Manual . 

The Z8001 uses five of its 64 memory segments. Segments and 17 
access the local PROM bank. Segment 3 accesses the low-order 
local RAM, and segment 5 accesses the high. Segment 9 is mapped 
into the Multibus memory; it is used for performing block moves 
between local RAM and the system RAM array. 

The Z8001 uses all three of its interrupt capabilities; vectored, 
nonvectored and nonmaskable interrupts. These are described in 
Disk and Tape Controller, section 6. 

The Z8001 is helped by two other onboard processors — a Z80 DMA 
chip and the disk sequencer. The DMA chip handles many of the 
details of passing data to and from the tape drive with minimum 
participation by the Z8001, and the disk sequencer performs a 
similar function for the disk drive (s). 



2.1. Bus Structure 

The IMSC processor address/data pins (AO through A15) are 
buffered by U88 through U91. These latch addresses to the LADR 
bus and data to and from the B'AD bus. These two busses go 
throughout the board, often latching to the other buses. The 
IMSC bus structure is described in Disk and Tape Controller, 
section 8. 



2.2. Local Ports 

The Z8001 makes extensive use of local ports to communicate with 
the various local peripheral devices. This is necessary to 
support the concurrent operations that it must perform 
constantly; it downloads instructions and expects the addressed 
device to implement them. It also reads status and makes 
decisions based on the status and/or passes the status to the 
system CPU. 

To write to the local I/O ports, the Z8001 places an address on 
the address bus (LAOO to LA15) . This causes the addressed port 
to input data from the B'AD bus. The Z8001 does this 
sequentially: it activates the address strobe (AS) to latch the 
address onto the address bus, then it activates its data strobe 
and R/W line to latch in the data. The R/W line is inverted into 
B'W/R to latch the data onto the XCVR bus when necessary. 
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The addresses, data, and functions are shown in the followinq 
table: 



Poet Signal D_££c_r_ip£ion 

00 Load disk sequencer 

memory address counter 



02 Host memory offset 
register 



04 LED/interrupt/parity 
control 



06 Load disk sequencer 
byte register 

10 Load utility register 



hits. Eit 



ption 



0-14 RAM address bits 
15 RAM segment select 
bit 

0-3 Host memory address 
bits 
4 Reserved. Must be 
HIGH 

0-6 LED bits. = ON 

7 1 = Enable parity 

8 1 = generate interrupt 

to host 

9 = parity clear 

0-7 Byte count 



Burst error processor 
(BEP) control request 

- sequencer 

1 - Z8001 

1 1 = enable memory 

holding register 
2-4 CO to C2 of BEP 

5 Disk read/write bit 

0=Write to memory 
l=Read from memory 

6-7 Clock select (binary) 



£fill£C_£ 
BITCT.K 



SQCLK 



00=Disk 125CLK 
01=Z8001 Z8001 
10=External External 
11=125CLK 125CLK 



8 Disk select tag 

9 Tag 1 

10 Tag 2 

11 Tag 3 
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20 

22 

24 



26 



30 



Z8001 to sequencer 
single-step 

Sequencer reset 

Load sequencer command 



Load sequencer ID and 
counter 

Disk select register 



12 Tape in read mode 

13 Tape in write mode 

14 Tape on-line 

(Active LOW) 

15 Disk data path MUX 

l=From sequencer 
0=Prom Z8001 



60 Tape data bus write 

70 Reset tape request 

80 Generate Z80 RETI 
signal 

90 Read board address 
strap 

A0 Diagnostic switches and 
sequencer counter 



0-2 Command code 

3 iK-byte sector select 

4 Reserved 

5 Command acknowledge 

preset by Z8001; 
cleared by 
sequencer 

0-7 Iteration counter 
8 -15 Sector ID 

0-9 Disk data bus 

10 Reserved 

11-14 Disk drive select 

15 Tape reset 



40 


Z8001 to BEP 


clock 






50 


BEP read port 





1 
2 
3 
4-7 
8 -15 


BEP error bit 

BEP EP bit 

BEP AE bit 

Unused 

BEP LP to 3 

BEP OUT (0 to 7) 



0-7 Data 



0-7 Store with 0ED and 
4D (hex) 

0-7 DIP switches (ON=0) 
8-15 Jumpers 

0-7 Diagnostic switches 
8 -13 Iteration counter 
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14 Parity error bit 

(Active LOW) 
(0=not power 
fail) 

15 Tape exception 

(Active LOW) 
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3. LOCAL MEMORY 



3.1. Memory Organization 

The IMSC board includes 8K words of PROM, 128K bytes of dynamic 
RAM, and 64K bytes of memory mapped into the Multibus memory 
space. The PROM occupies segments and 17 of the IMSC Z8001 
address space. The low half of the dynamic RAM (64K bytes) 
occupies segment 3, and the high half occupies segment 5. The 
64K bytes of Multibus address space occupy segment 9. 

The PROM memory is used to store diagnostic and bootstrap 
programs for the disk and tape drives. The dynamic RAM is used 
to buffer information from the disk and tape drives before 
passing it on to the system memory, and to store large blocks of 
Unix disk programs. The Multibus memory space is used to pass 
information over the Multibus to and from system memory. 

3.2. Local Dynamic RAM Access 

The 128K bytes of dynamic RAM on board is shown on page 2 of the 
IMSC schematics. 

The RAM chips (Ul through U8 and U21 through U28) are 64K-by-l 
bits wide, and are wired for parallel operation. The 16 bits of 
any one word are stored at identical addresses in all 16 chips. 
The MEMBUS has one line attached to the input and output of each 
RAM chip. The addresses appear on the multiplexed address bus 
(MADR to 7) , and are latched into memory by the proper 
combination of B'RAS/ 1 and 2, CAS EVEN and ODD/, and B'RW/ 1 and 
2. 

The RAS/CAS operation is typical. When CAS is enabled, the data 
on the MADR bus is interpreted as a column address; when RAS is 
enabled, it is interpreted as a row address. Each column and row 
address enables a single bit in all 16 chips. 

The CASEVEN/ and CASODD/ lines can be used to select a byte-only 
access to either the high- or low-order byte of a word. The CAS 
line is deactivated for the unused byte. 

Signals B'RW 1 and B'RW 2 control the direction of data flow for 
the high- and low-order bytes. Provided with a row and column 
address, and a direction of data flow, each RAM chip outputs (or 
inputs) its one bit of data on (or from) the MEMBUS. Data from 
the MEMBUS is latched onto the B'AD bus by a combination of paks 
U45, U46 and U48. 
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NOTE: The 4164 RAM chips are able to operate properly with 
their inputs wired to the outputs because they sense the 
proper direction of data flow and tristate their gates when 
necessary (during input operations) . 

To arrive on the MADR bus, the multiplexed address bits first 
must be latched from the Z8001 outputs to the address bus by U88 
and U89. Since this is a 16-bit data path and the CAS and RAS 
addresses are only 8 bits each, they must be multiplexed by U3 2 
and U33. 

3.2.1. Parity 

The parity circuit is shown on page 4 of the IMSC schematics. 

U9 and U29 are 4164 RAM chips wired into the memory circuit in 
the same manner as Ul through 08 and U20 through U28. The RAS, 
CAS and B'RW signals perform exactly the same as in the RAM 
circuit. The only difference is that the data inputs and outputs 
of 0*9 and U29 are connected to the EVEN outputs of U44 and U50, 
which are parity generation chips. 

During write operations, the data on the B'AD bus is fed into the 
parity generation chips, and the EVEN outputs are stored in U9 
and U29. During read operations, the data on the B'AD bus is 
again fed into the parity generation chips, which produce an EVEN 
output. This is compared with the output of U9 and U29 by an 
exclusive OR (U10) . Any difference produces an output, which 
activates PAR' ERR and NMI/. 

3.3. Memory Arbitration 

The IMSC processor, the disk sequencer, and the tape DMA all 
compete for access to local RAM. This is not a direct, one-on- 
one competition. The disk sequencer and the IMSC processor 
compete with each other, and the tape DMA fills in for the IMSC 
processor when it is active. 

The IMSC processor and the disk sequencer access local RAM by 
taking control of the MADR bus, and the memory control lines 
(CAS, RAS and WE). The final stage in the contention is U97, 
which forces the IMSC processor into a wait state when the disk 
sequencer is in control. When both devices require access, the 
cycles are interleaved; first one then the other is granted a 
memory cycle. 

The tape DMA looks exactly like the IMSC processor when it is 
active. It performs a formal DMA request and forces the IMSC 
processor to give up control by tristating its outputs. It then 
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mimics the IMSC processor by generating and receiving exactly the 
same signals. 

3.4. Local PROM 

The local PROMs occupy segments and 17 in the IMSC Z8001 
address space. They contain diagnostic and bootstrap programs 
for the disk and tape drives. 

The local PROM circuit consists of four 4K-by-8 PROMs (U54 and 
U57, and U71 and U72) , an 8-bit latch for each PROM, and the 
ENROMBKO/ line. The PROM circuit contains 8K words (16K bytes). 

If the bits on LA01 to LA12 match an address in the PROM circuit, 
both PROMs in the set output their data into the buffers, which 
must be enabled by ENROMBKO/. When the latches are enabled, they 
latch data onto the B'AD bus. Because all PROM accesses are for 
entire words, bit LAOO is not used. 

The IMSC processor selects between segments and 17 with its SN 
to SN 5 lines. These are read as a binary number; SN alone 
accesses segment and SN with SN 4 accesses segment 17. This 
logic is shown in the IMSC schematics, page 5. 

Because the PROMs and latches are 8-bit devices, two PROM and 
latch circuits are required for each set. Both PROMS receive the 
same address, and both latches are enabled by the same sianal 
(ENROMBKO/) . * 

This circuit is shown in the IMSC schematics on pages 5 and 22. 
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4. MULTIBUS INTERFACE 

The IMSC performs all its interaction with the rest of the system 
over the Multibus. It can act as both a bus master and a bus 
slave. The B'AD bus and the address bus (LADR to 15) both 
connect to the Multibus. This circuit is shown on page 18 of the 
IMSC schematics. 



4.1. Bus Arbitration 



The IMSC competes for the Multibus exactly like any other 
Multibus master in the P/25. When it requires the Multibus, it 
enables a CTC output to generate a bus request every millisecond. 



After the bus request is activated, two steps must 
before the IMSC can receive the Multibus. 



be completed 



First, the bus request enters the bus priority logic circuit on 
the backplane. This circuit returns BPRN, based on the IMSC's 
bus priority. 

Once the IMSC receives BPRN, it polls its BUSY line to see if any 
other master is on the bus. As soon as BUSY goes inactive, it 
pulls BUSY high to keep other bus masters off, then proceeds with 
its bus transaction. 



The amount of time any master can keep the Multibus is controlled 
by a timing circuit in the master. In this case, an MRES 
instruction releases the Multibus by releasing BUSREQ, which also 
causes it to release BUSY. The IMSC is allowed to keep the 
Multibus long enough to transfer 256 bytes (400 microseconds) . 



The instructions to set this time are 
chip by software. 



downloaded into the CTC 



4.2. Data Transfer 

Data is passed between Multibus lines DATO to DAT15 and the B'AD 

bus by U14 and U15, which are bidirectional transceivers. When 

the output of U140 pin 8 and U20 pin 8 both go low, data flows 

from the Multibus to the B'AD bus. When U20 pin 8, which is an 

inverted version of B'R/W, goes high, data flows from the B'AD 

bus onto the Multibus. Any other combination causes both 
directions to assume the high impedance state. 

The low-order byte of the Multibus data lines (DATO to DAT7) is 
also latched into U34, which is enabled by LD MOFF/. U34 latches 
this data into U12, which outputs BA'DOO to B'AD04 onto the 
Multibus as BHEN and AD10H to AD13H. U12 is enabled by the 
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output of D140 mentioned above. 

The low-order data byte from the Z8001 (DATOO through DAT07) can 
also be latched onto the B'AD bus by the combination of U13 and 
U35. This transfer is enabled by the CEMULTIBUS signal from 
U144. 



4.3. Address Transfer 

The address bus lines (LAOO to LA15) are latched onto the 

Multibus by U16 and U17, which are enabled by O140 pin 8. These 

addresses access system memory through the MMU (located on the 
processor board) . 

When the CPU wants to communicate with the IMSC, it places the 
IMSC's wakeup address on ADDOO to ADD07. These pins feed into 
U37 and U38 f which are 4-bit comparators. This byte is compared 
with the levels set by SW2, which defines the IMSC's wakeup 
address. If they are identical, U37 generates an output which is 
ANDed with IOWC/ in U96 and used to start the channel attention 
sequence. 
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5. IHSC CONTROL 



5.1. CPU Controlling IMSC 

The CPU controls the IMSC the same way it controls the ICPs; it 
builds a command block in its memory at the IMSC's wakeup/channel 
attention address, then issues a channel attention to the IMSC, 
which reads the command block and executes the instructions 
there. 

Typically, the command block contains a pointer to another block 
of data, and instructions for handling that data. For example, 
the command block might say (in data structures) "go to memory 
location 50,128H and write the next 40 blocks onto the disk". 

The following is an example of a CPU-to-IMSC command sequence: 

NOTE: This example describes a memory-to-disk write 
mentioned in the preceding paragraph. 

a) The CPU writes the data in system memory and puts a 
pointer and a command block in the IMSC's wakeup address. 

b) The CPU issues a channel attention to the IMSC. 

c) This causes a local vectored interrupt to the IMSC 
processor. 

d) The IMSC requests and (eventually) receives the Multibus. 
The signal used to request the bus is 796'BUSREQ. The IMSC is 
notified that it has the bus when it receives 796*BPRN. 

e) The IMSC reads the contents of the command block into IMSC 
local memory, then releases the Multibus. 

f) The IMSC processor executes the instructions in the 
command block. In this case, the block orders the IMSC to 
write a block from memory to disk. 

g) The IMSC again requests the Multibus through the same 
procedure as before. It writes the first chunk of the data 
block in its buffer, releases the bus, and repeats the bus 
request sequence. When the bus is granted, it fetches the 
next chunk of data. It continues doing this until the entire 
data block, as defined in the command block, is in the IMSC 
local memory. 

h) Once all the data is received, the IMSC requests the 
Multibus one last time and writes a 'command status' block. 
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It then asserts its 796' INT line, which generates an interrupt 
to the CPU processor. The CPU responds by reading the command 
status block. 



5.2. IMSC Controlling Disk 

The IMSC controls the disk drive (s) through two paths, the disk 
sequencer and the command bus. The commands passed over each of 
these paths are listed below: 

sequencer Commands 

Write Data 
Format 
Read Data 
Read ID 
Idle Loop 
Diagnostic 

Command fins Commands 

Drive Select 

Seek 

Clear Faults 

Move Data Strobe Early 

Move Data Strobe Late 

Both command paths are described in the following sections. 

5.2.1. Disk Sequencer 

The disk sequencer is shown on page 12 of the IMSC schematics. It 
converts commands from the IMSC processor to a stream of output 
bytes that implement the commands. 

The disk. sequencer is activated when the command latch (U131 and 
132) latches data from B'AD lines 0, 1, and 2 onto pins A8, A9 
and A10 of the sequencer PROMs. These three bits define one of 
the six disk sequencer commands. 

To implement each of its six commands, the sequencer must step 
through up to 128 instructions. Pins A8 through A10 initialize a 
command sequence, and the PROMs output the instructions. 

The PROMs are divided into two banks, each containing two 2K-by-4 
PROMs. The first bank is the state PROM bank (U151 and U152) , 
which recognizes the command on A8 through A10. It outputs an 
address on its output pins. These are latched by U150 onto pins 
A0 through A6 of the data PROM bank (U153 and U154 — PROMs are 
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each IK by 4) , which outputs an instruction on SQDATA. SQDATA 
then accesses the next byte in the state PROM bank, which outputs 
the next address. This sequence continues until the command is 
implemented. 

The data byte output on SQDATA is divided and passed to several 
places on the IMSC board. These are not coherent bytes to be 
read and processed by any one device; they are latched off SQDATA 
and immediately go their separate ways. The following paragraphs 
describe some of the uses of this data. 

SQDATA through 7 are latched sequentially from U136 to 0117 
every time DKWDLD* pulses. The output of U117 provides the 
various disk control (DKCTL) signals 

U134 and U155 are a word up-counter which use SQDATA to count the 
number of words in a disk transaction. The sequencer first 
provides it with a word count. When it reaches that count, it 
activates SQCNTOVF. The word count comes over SQDATA. 

U137 latches SQDATA through 4 onto SYN SQDATA every time SQCLK 
pulses. 

5.2.2. Disk Command Bus 

The disk command bus pins are shown in the IMSC schematics on 
page 15. These are BUS through BUS 10, TAG 1, TAG 2, TAG 3 and 
SELECT TAG. The commands that are sent over these pins are 
listed earlier in this section. 

5.2.2.1. Implementation 

The command bus commands are implemented by writing data on the 
command bus and toggling the TAG lines. The command data is 
latched off the B'AD bus by U168 and U171. These outputs 
activate the command bus output chips (U188, U189, U190 and 
U191) . The TAG lines are activated by U192. 

The command sequence is as follows: 

Select — Write the disk drive number to the command bus and 
activate SELECT TAG. 

Seek — Write the cylinder address to the command bus and 
activate TAG 1. Write the head address to the command bus and 
activate TAG 2. 

Clear Fault, Return to Zero, Move Data Strobe — Write the 
appropriate bits to the command bus and activate TAG 3. 
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NOTE: The proper bit patterns for the command bus are 
provided in the disk drive manual. 

5.3. ID Equate Latch 

The desired disk sector is read from B'AD 8 through 15. These 
bits are latched by U114 and U115 and presented at the "A" inputs 
of U116, which is an 8-bit comparator. The disk reads sector 
IDs as they go by, and these appear on the "B" inputs. When the 
inputs match, the correct sector has been reached, and the 
comparator generates DKIDEQ* to inform U135 that the proper 
sector has been identified. 



5.4. Serial-to-Parallel Conversion 

During disk write operations, memory words from the MEMBUS are 
stored in U63 and U65 (one byte each) until the serial-to- 
parallel conversion circuit (see the IMSC schematics, page 10) is 
ready. The word is latched onto the SERBUS, which appears on the 
pins of U82 and U83. These convert it to a serial bit-stream 
(SERDES) . 

During disk read operations, the serial bit-stream from the disk 
(DKRDATA) is fed into U82 and U83 , which convert it into parallel 
words. These are output on the SERBUS, and latched onto the 
MEMBUS by U62 and U66. They can also be multiplexed onto SERHR 
one byte at a time by U102 and U105. SERHR connects to the disk 
ID EQUATE circuit and the ECC processor. 

5.5. Disk Interface 

The connections from the IMSC to the disk(s) are shown in the 
IMSC schematics, pages 13 and 14. 

Each disk has two cables connecting it to the IMSC. Connector Jl 
is 60 pins wide. It connects to all disks in series. Any signal 
which must go to all disk drives is on Jl. 

J2 and J3 are each divided so as to connect to two individual 
disks each; J3 connects to disk 1 and 2, and J2 connects to disks 
3 and 4. Any signal which must go only to one particular disk is 
on J2 or J3 . 



5.5.1. Differential Drivers 

The IMSC uses differential signals to communicate to the disks. 
The output chips divide each signal into a positive and a 
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negative component which is transmitted on two lines. The 
receivers compare both components and translate the result back 
into a single signal. This arrangement protects against 
transmission errors and signal decay. 

5.5.2. Inputs 

The disk data receivers (U176 through U179) each receive the READ 
DATA, READ CLK, and PLO CLK inputs from one disk. These chips 
are enabled by the disk select (DRSELD 1 through 4) lines. The 
„i s L sele ? t signals are generated by 0175, which receives the 
SELECTED signals from the disks. This arrangement ensures that 
only a selected disk can have its outputs read. 

5.5.3. Outputs 

The bit-stream to be written on the disk (WRDATA 1 through 4) and 
£?!L Wri ^ e clocks <WRCLK 1 through 4) are generated by U193 and 
U194. These chips make no distinction about which disk they are 
transmitting to; their inputs are all common and their outputs 
are identical on all pins. U193 converts the bit-stream from 082 
(the parallel-to-serial converter) into the differential signal 
„?L transmission to the disk drives and outputs it on all pins. 
0194 does the same with BITCLK. These signals appear at all disk 
drives; only the selected drive inputs it. 

5.6. IMSC Controlling Tape Drive 

The IMSC is connected to the intelligent tape drive by 16 pins in 
a 50-pxn ribbon cable. Eight of these transmit data to and from 
t2!L ? e drive * The other ei g h t are control lines, used by the 
IMSC to control the tape drive and by the tape drive to 
communicate with and acknowledge the IMSC. 

5.6.1. Tape Data Bus 

The tape data bus (pins HBO through HB7) is buffered by 0184 
which is bidirectional. The direction of data throuqh 0184 is 
controlled by TPBON* which is derived from the tape drive Dll 
output. The tape drive asserts DIR to cause the IMSC to output 
data on the tape data bus. When DIR is low, data flows from the 
tape drive to the B'AD bus through 0184. 

7Snn? aP L^ at J 5 US 5 1 ! transmits command data from the IMSC 

Z8001, and status data from the tape drive to the IMSC. When the 

HrfL r £JV 8 , ln C° MMAND MODE, the REQ* line informs the tape 

drive that valid command data is on the tape data bus. When the 
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tape drive is in the STATUS INPUT mode, the controller asserts 
REQ to inform the tape drive that it has received status data 
placed on the tape data bus by the tape drive unit. 



5.6.2. Control Lines 



The following table shows the tape drive to IMSC control lines 
and provides a brief description of their functions: 



IMSC to Tape Drive 



Identifier 



Signal 

Name 



Description 



RST 



XFER 



REQ 



RESET Causes the tape drive to reset. This is 
reserved for system resets or powerup. 

TRANSFER Informs the tape drive that data has 

been placed on the tape data bus during 
WRITE mode and that data has been read 
from the tape data bus during READ mode. 

REQUEST Informs the tape drive that command data 

has been placed on the tape data bus during 
COMMAND mode and that status data has been 
read from the tape data bus during 
STATUS INPUT mode. 



ONL 



ON-LINE 



Tape Drive to IMSC 

Signal Signal 
Identifier Name 



Activated prior to transferring a 
READ or WRITE command and deactivated 
to terminate the command. 



Description 



DIR — DIRECTION Controls the direction of data on the tape 

data bus. When inactive, causes the IMSC 
to output data on the tape data bus. When 
active, causes the tape drive to output 
data. 



ACK — 



ACKNOWLEDGE 



RDY -- 



READY 



Informs the IMSC that data has been taken 
from the tape data bus during WRITE mode and 
that data has been placed on the tape data 
bus during READ mode. 

Informs the IMSC that data has been taken 
from the tape data bus during COMMAND mode 
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and that data has been placed on the 
tape data bus during STATUS INPUT mode. 

EXC ~ EXCEPTION Informs the IMSC that an exception exists 

in the tape drive unit, and that the IMSC 
must issue a STATUS command and perform 
a status input to determine the cause 
of the exception. 

As shown in the above table, the control line used and the 
meaning of data on the tape data bus is a function of the tape 
drive mode. 

5.7. Tape DMA 

Tape-to-memory data transfers are handled by U107, a Zilog Z80 
DMA chip described in the .ZjJLoa M DMA Technical Manual. This 
chip is shown on page 8 of the IMSC schematics. 

Because most of the pins on the Z80 DMA chip are bidirectional, 
control of this chip is somewhat complicated. The descriptions 
in this section are divided by functions according to what the 
DMA chip is required to do. 

There are three basic functions that the Z80 DMA chip is required 
to perform: a) read instructions from the IMSC Z8001, b) write 
data from system memory to the tape and c) read data from the 
tape into system memory. These are described below. 

5.7.1. DMA Receiving Instructions 

Before the DMA chip can function, it must be programmed by the 
IMSC Z8001. The Z8001 must first place it in the receive 
instruction mode, then download the instructions. 

To prepare the DMA chip to receive instructions, the Z8001 must 
activate CE*, IORQ* and WR* on the rising edge of the DMA clock 
(250CLK*). The data byte must be stabilized on the XCVRBUS by 
the rising edge of the next clock pulse. This data is latched 
off B'AD through 7 by U87, which is enabled by ENXCVR*. 

5.7.2. Tape-to-RAM Transfers 

Before a DMA can take place, the Z8001 programs the DMA chip with 
a source port, a destination port and a block length. This is 
done as described above. 

To implement the instructions it received from the Z8001, the DMA 
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takes over control of its buses. To the devices on the buses, 
the Z8001 appears to be in control; this chip is designed to 
simulate it. 

The DMA chip activates BUSREQ* to force the Z8001 to give up 
control (tristate) its outputs. The Z8001 returns BUSACK* to 
signal the DMA chip that it is in control. The DMA chip then 
requests the Multibus. When the Multibus is granted, BAI* goes 
low, and the DMA starts transferring data. 
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6. INTERRUPTS 

The IMSC uses all three of the Z8001 interrupt capabilities: 
vectored interrupts, nonvectored interrupts and nonmaskable 
interrupts. 

6.1. Vectored Interrupts 

Vectored interrupts are used by the DMA chip, the CTC chips and 
the SIO. When one of these has a reason to interrupt the Z8001, 
it asserts its INT/ line, which connects to the Z8001 VI input. 
The Z8001 acknowledges the interrupt by asserting IORQ/ and Ml/. 
It then looks for the interrupt vector, which is output by the 
interrupting device on the XCVR bus. 

Each of the vectored interrupt-producing chips is programmed with 
the proper vectors, which provide one of the boundaries of the 
interrupt-handling routine. This data is latched from the XCVR 
bus to the B'AD bus, to the ADO to AD7 pins of the Z8001. 

The interupt is cleared when the Z8001 causes IORQ'PERIPH and Ml/ 
to go low and P'RD to go inactive (high) . 

The DMA chip generates an interrupt to notify the Z8001 that it 
has completed a block transfer. CTC 1 interrupts the Z8001 in 
the event of a bus grant or a CPU Multibus interrupt reset. CTC 
2 interrupts the Z8001 to signal a channel attention. The SIO 
interrupts the Z8001 when it receives a character or when it 
receives a status change from the terminal. 

The vectored interrupt priority is arranged by a daisy chain 
consisting of the IEI/ and IEOV lines of the DMA, CTCs and SIO. 

6.2. Nonvectored Interrupts 

The only nonvectored interrupt is used for diagnostics and 
debugging. The diagnostic software controls a switch which 
generates this interrupt to freeze all processes at their present 
state without disabling the CPU. This technique allows 
diagnostic personnel to inspect the state of the board at the 
time of the failure. 

6.3. Nonmaskable Interupts 

Because there are valid reasons for disabling most interrupts, 
nonmaskable interrupts are only used when action must be taken 
regardless of other conditions. In the IMSC, this is only done 
in the event of a parity error or a power failure. 
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7. DMA 



7.1. Overview 

To qualify as a DMA, a circuit has to receive orders to move a 
block of data, and then move it without any more participation by 
the ordering device. In the IMSC, there are two true DMA 
circuits and one pseudo-DMA circuit. The disk sequencer provides 
DMA between the disk drives and the IMSC dynamic RAM. A Zilog 
Z80 DMA chip provides DMA between the tape drive and dynamic RAM, 
and the IMSC processor provides pseudo-DMA between the IMSC 
dynamic RAM and system memory array. This is not a true DMA 
because the processor gets involved. 

7.2. Disk to IMSC Transfer 

The disk sequencer provides the DMA function to transfer data 
between the disk and the IMSC dynamic RAM. This is a true DMA; 
the IMSC processor does not get involved after it issues the 
original commands. 

Before the disk sequencer can begin a DMA transfer, it must 
provide various disk sequencer registers with the information 
that the sequencer will need to perform its function. To do this, 
it places the port address of the register to be loaded on the 
address bus. This enters U70, U144 and U160, which generate 
enables for the register to be loaded. The data for the register 
is then placed on the B'AD bus and appears on the input pins. 

The IMSC processor must load registers with the following 
information before starting the sequencer: 

Starting memory address — Loaded into U98 through U101. When 
DKMUX is activated, this data is multiplexed down to 8 bits by 
U80 and U81, which output it on MADRO to MADR7. This accesses 
a word in local RAM. That word is output on the B'AD bus for 
transmission to the disk during write operations and is read 
from the disk during read operations. The memory address in 
U98 through U101 is incremented by one and the process is 
repeated 

Sector ID — U114 and U115. When the disk reaches the proper 
track, it starts reading sectors into U102 and U105, which 
compare them with the sector loaded into U114 and U115. U116 
generates DKIDEQ/ when they match. 

Sector count — U112 and D113. Because the minimum amount of 
data moved to or from the disk is one sector (512 bytes) , this 
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count controls the amount of data moved. 

Command — U131. This controls the type and direction of the 
action. The entire menu of disk sequencer commands is defined 
by the data in this latch. These commands are listed in Disk 
and Tape Controller, section 5.2. 

When all the registers are loaded and the IMSC processor is ready 
to begin the DMA, it enables the command latch by activating 
uPSQ/LDCMD* (U132) , which latches the command into the sequencer 
command latch. This ends the IMSC processor's involvement until 
the sequencer notifies it that the DMA is complete. 

7.3. Tape DMA 

The tape DMA is implemented with the Z80 DMA chip shown on page 8 
of the IMSC schematics. 

This chip works much like the disk sequencer in that the IMSC 
processor must load it with a starting address, a byte count and 
a command mode. This is different from the disk sequencer in 
that all this information is written to one place; it is stored 
in internal registers in the DMA chip, which is a port in the 
IMSC processor's I/O space. 

This circuit goes through two distinct phases to accomplish its 
task. During the first phase, the IMSC processor programs the 
DMA chip. In the second phase, the DMA chip executes the program 
and transfers the data. 

7.3.1. Programming the DMA Chip 

When the IMSC processor wants to program the DMA chip, it 
activates DMAWR/ and writes a sequence of control bytes on the 
B'AD bus. These are latched onto the XCVR bus to appear on pins 
DO to D7 of the DMA chip. The DMA chip must receive the 
following information: 

Byte Count — The number of bytes to be transferred. 

Port A Address — The address in local memory where the 
transfer is to begin. This is a variable address that will be 
auto-incremented by the DMA chip. 

Port B Address — The fixed address of the tape drive. 

Control Bytes — Determine the direction of data transfer and 
other internal details. 
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Interrupt ID — Initializes the DMA with a vector ID, which is 
returned to the processor on DMA interrupt. 

7.3.2. Transferring the Data 

When the DMA chip is ready to begin, it asserts BUSREQ, which 
causes the IMSC processor to give up control of the relevant 
buses and return DMA BUSACK/. Then, depending on whether the 
control bytes specified a tape write or read operation, the DMA 
and tape drive perform an XFER/ACK cycle, and the data is 
transferred to (or from) the tape. 

Meanwhile, the DMA must control the local memory, either to get 
the data from there (tape write) or to store it there (tape 
read) . It activates DMAMRQ, which U122 uses to generate three 
signals which eventually become uPMRAS, uPMCAS and B'RW. These 
control the B'AD bus, the MEMBUS, and the XCVR bus. The DMA chip 
is arranged internally to output the proper address and data to 
correspond to the CAS, RAS and B'RW signals in local memory 
(RAM) . 

The DMA chip is in the circuit in parallel with the processor, 
which gives up control of the buses and allows it to take over. 
To the latches and other devices involved, the Z8001 appears to 
retain control. 

The DMA control cycles are interleaved with the IMSC processor 
cycles. 

7.4. Local RAH to Memory Array — Pseudo DMA 

The transfers from the IMSC local RAM to the system main memory 
array are implemented using the block move capability of the 
Z8001. This is not a true DMA because the processor gets 
involved. 

To accomplish a block move, the IMSC processor gives itself 
instructions. It loads the beginning memory address and byte 
count, and requests the Multibus. Upon receipt of the Multibus, 
it moves the entire block. The blocks are kept small enough so 
they can be moved in a single Multibus access. A typical block 
is 128 to 256 bytes long. 

The block move is implemented by using the portion of the IMSC 
processor's memory space that is mapped into the Multibus memory 
space. The processor orders data to be written into (or out of) 
segment 9 of its memory space. This causes it to access the 
Multibus and transfer data to (or from) system main memory. 
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8. LOCAL BOS STRUCTURE 

The IMSC requires an elaborate system of buses to maintain three 
concurrent DMAs. These buses, which are shown in Figure 1, are 
described below: 

uPADBUS — Takes AD to AD 15 from the Z8001 to a series of 
latches (U88 through U91) , which latch data to and from the 
B'AD bus and addresses to and from the LADR bus. 

B'AD bus — The primary carrier of data to and from the Z8001. 
Latched from the uPADBUS by U90 and U91. 16 bits wide. 

LADR bus — The primary carrier of addresses to and from the 
Z8001. Latched from the uPADBUS by U88 and U89. 16 bits 
wide. 

MADR to 7 — Carries addresses from the LADR bus. The 16- 
bit addresses are multiplexed by U32 and U33 into 8-bit bytes. 
Carries addresses to local RAM and to the disk sequencer. 8 
bits wide. 

MEMBUS — Carries 16 bits between the B'AD bus (latched by U45 
and U48) and the data pins of local RAM. Also goes to U62 and 
U66, which latch data to and from the SERBUS. 

SERBUS — Main purpose of this bus is to carry 16 bits of data 
to and from U82 and U83, which are the serial-to-parallel 
conversion chips used to transmit and receive from the disk 
drives. Can latch data to and from the MEMBUS and the B'AD 
bus. 

SERHR — Takes disk sector IDs from the SERBUS to the disk ID 
equate register (U116) and takes all disk data to U84. Bytes 
are latched onto it by U102 and U105. 8 bits wide. 

SQDATA, SQSTATE — Used to pass information around in the disk 
sequencer. Selected bits are used to generate control logic 
which controls the disk drive. 

XCVR — Carries data to and from the CTCs, SIO and DMA chips. 
The data is latched on and off the B'AD bus by U87. 
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9. CTCS AND SIOS 



9.1. Counter Timer Circuits 

The IMSC has two Z80 CTC chips on board. Each of these has four 
channels (0 to 3) . Each channel has a unique function. The IMSC 
processor downloads programs and time constants for each channel. 
Programming details are in the Zilog 1981 Data Book . The 
following paragraphs provide an overview of the function of each 
channel. 

CTC 0, Channel — Generates multibus requests. It is 
programmed to operate in the timer mode and to generate an 
output roughly every 1 millisecond. The ZCTO0 signal turns 
into BUS'VgS'ARB'REQ. 

CTC 0, Channel 1 — Generates the baud rate for serial port 0. 

The diagnostic software tells the IMSC processor to program it 

for the proper baud rate, which may be between 50 and 38,400 
baud. 

CTC 0, Channel 2 — Not used. 

CTC 0, Channel 3 — Interrupts the IMSC processor when the 
system CPU processor wants to reset the Multibus interrupt. 
It is programmed in the counter mode to generate an output on 
every input. The input is PORTADD'IR, and the output is 
VECT ' INT/ . 

CTC 1, Channel — Generates the baud rate for serial port 1. 
The details are the same as CTC 0, channel 1. 

CTC 1, Channel 1 — Not used. 

CTC 1, Channel 2 — Not used. 

CTC1, Channel 3 — Programmed in the vectored interrupt mode. 
It sends a local vectored interrupt to the IMSC processor when 
the CPU processor sends a channel attention. The input signal 
is PORT'ADD'CA/. The IMSC processor demands a local interrupt 
vector, which CTC 1 puts out on the XCVR bus. 

9.2. Serial Input/Output 

The IMSC has two serial input/output channels on board. These 
are used for factory and field diagnostics, in conjunction with 
the diagnostic software. 
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The connecting and control circuitry for these ports is very 
basic and simple. The baud rates come from the CTC chips, the 
data comes from the XCVR bus, and the only connections to the 
terminals is TxD, RxD and ground. They are almost completely 
controlled by the diagnostic software. 



9-2 Disk and Tape Controller 



Plexus Computers Inc P/25 ENGINEERING MANUAL 



10. ERROR HANDLING 



10.1. Overview 

The IMSC has three different local data error handling circuits. 
Disk errors are detected and corrected by an ECC chip which uses 
a 32-bit polynomial code (see the IMSC schematics, page 10) . The 
intelligent tape drive provides its own error-handling capability 
transparent to the IMSC. The IMSC uses a byte-parity system (see 
the IMSC schematics, page 4) . 

10.2. Disk Errors 

To ensure that what is written on the disk is exactly what is 
read, the IMSC uses an ECC chip that generates a 32 bit 
polynomial error code. 

The ECC chip (U84) reads bytes from SERHR as they are written on 
the disk. At the end of each sector, it outputs 4 bytes on the 
SERBUS. These are stored on the disk at the end of the sector. 

When the sector is read from the disk, the 4 bytes (32 bit 
polynomial code) are read with it. The entire sector plus the 32 
bits are fed back through the ECC chip and a new polynomial code 
is generated. 

The nature of the 32 bit polynomial code used is such that if an 
identical sector plus the code is coded again, the resulting code 
must equal zero. Any other result means that the data was not 
correct. This condition causes U84 to activate ERR. The IMSC 
software then uses the polynomial code to reconstruct the 
original data. 

10.3. Tape Drive Errors 

The intelligent tape drive provides its own error detection and 
correction without participation by the IMSC. When it is 
necessary to inform the IMSC, it sets its exception (EXC) line, 
which causes the IMSC to request the status. The IMSC software 
provides the proper response, based on the status read in. 

When the intelligent tape drive signals an error that it cannot 
correct, the IMSC software informs the operating system. 
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10.4. Local Memory Errors 

The IMSC dynamic RAM circuit uses a parity circuit to detect 
errors. The RAM bank is composed of sixteen 64K-by-l-bit RAMs. 
Two identical chips read in the parity bit generated by U44 and 
U50. When the data is read out of RAM, U44 and U50 again 
generate a parity bit each, and they are exclusive ORed in U10 
with the previously stored bit. If they do not match, the 
exclusive OR generates an error output. 

This circuit is explained in Disk and Tape Controller, section 3. 
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